IDL Quickstart
IDL Quickstart
IDL Quickstart
IDL® is a registered trademark of ITT Visual Information Soutions for the computer
software described herein and its associated documentation. All other product
names and/or logos are trademarks of their respective owners.
Table of Contents
1. Introduction to IDL 5
What is IDL? 5
Introduction and Resources 5
The IDL Development Environment 7
Installing the Tutorial Files 9
The Power of IDL 9
A Brief Tour of the IDL Language 10
5. Volume Rendering 65
Displaying 3-Dimensional Volumetric Data 65
Data Space Scaling 68
Volume Object Properties 69
Image Planes, Subvolumes, and Isosurfaces 75
What is IDL?
IDL, the Interactive Data Language, is an interpreted computer language and
interactive software environment that is ideal for data analysis, visualization, and
cross-platform application development. IDL is specifically designed for the
visualization and analysis of large, multi-dimensional technical datasets. IDL is the
language of choice for technical professionals, offering simple syntax, array-oriented
architecture, and rich library of analysis and visualization routines. IDL combines all
of the tools individuals need for any type of project -- from “quick-look”, interactive
analysis and display to large-scale commercial programming projects.
IDL has a rich library of built-in mathematical, statistical, signal & image processing,
and analytical routines that provide proven algorithms that developers and scientists
can rely on. The language is specifically designed for visualizing large and complex
datasets, from simple 2D plots to powerful OpenGL-accelerated 3D graphics. In
addition, IDL reads and writes virtually any data format, type and size, reducing the
time users spend dealing with file I/O. Thousands of technical professionals use IDL
every day to rapidly develop algorithms, graphical user interfaces, and powerful
visualizations with the ability to quickly crunch through large numerical problems.
All of this is available in an easy-to-use, high-level, fully extensible programming
environment.
ITT is committed to providing the highest quality level of customer support and
assistance to our customers, and we provide a variety of support services to help
users be as productive as possible. In addition to the IDL Quick Start tutorial, the
ITT Global Services Group offers a more extensive training program that consists of
a series of courses taught with hands-on instruction by a team of skilled
professionals. ITT provides training classes across the country on a regular basis at
a number of locations, and can also do custom on-site instruction when needed.
Furthermore, the ITT Global Services Group also provides consulting, and we
specialize in building complete solutions for unique data analysis and visualization
applications. The ITT team of responsive, creative consultants is ready to listen and
deliver what the users want -- on time and within budget. They can help define
There are a number of resources that are available to individuals working with the
IDL software package, and several of these resources can be found on the ITT
website (www.ittvis.com). Some of these resources include :
Finally, the IDL software package also includes a complete set of documentation
manuals in either PDF format or the built-in Online Help system, which can be
accessed by selecting “Help > Contents…” from the IDL development environment
window. Another very good resource for individuals just getting started with the IDL
software package is the Getting Started with IDL documentation manual [Fig. 1-1].
• Windows: select “Start > All Programs > RSI IDL #.# > IDL”
• UNIX et al.: execute “idlde” at the shell prompt
• Mac OS X: double-click “/Applications/rsi/idl_#.#/idlde”
Note: If executing “idlde” doesn’t work on UNIX and Linux, the IDL setup file (that defines environment
variables specific to IDL) needs to be sourced. This setup file is found in the “bin/” subdirectory of the IDL
installation. For example, with an installation of IDL in the default “/usr/local/rsi/” location the
appropriate commands would be :
Bourne or Korn shell: $ . /usr/local/rsi/idl/bin/idl_setup.ksh
C or TC shell: % source /usr/local/rsi/idl/bin/idl_setup
It is a good idea to setup user accounts to source these files upon login in the resource configuration file in
their home directory (e.g. .cshrc, .login, .kshrc, etc.).
After launching IDL the main IDLDE window appears [Fig. 1-2]. The eight sections of
this window are described below. On Windows, most sections of the IDLDE can be
undocked (click and drag) and resized by moving the separator. In addition, each of
these individual sections, except the Document Panel and Main Menu Bar, can be
turned on or off under the Window menu.
The Toolbar
Toolbar buttons provide a shortcut to execute the most common tasks found
in the main menu.
At this time, please perform the appropriate steps for your operating system to copy
the entire “IDL_QS_Files” folder to the appropriate location on the computer. The
default installation location for IDL that this folder should be copied to is :
• Windows: C:\RSI\IDL##\
• UNIX et al.: /usr/local/rsi/idl_#.#/
• Mac OS X: /Applications/rsi/idl_#.#/
Individuals who are new to IDL or have not been exposed to the software before
may be interested in seeing some demonstrations of how the software can be
utilized. One of the best ways to get a feel for the capabilities of IDL is to run the
built-in demo system, which can be accessed by pressing the button on the IDLDE
toolbar or executing the command DEMO at the IDL> command prompt :
IDL> demo
Note: The IDL source code for these demonstration programs can be found in the
“examples/demo/demosrc/” subfolder of the IDL installation.
The demonstration programs are launched by a category on the left-hand side, then
double-clicking on the link in the lower-right hand corner.
1. IDL> PRINT,2*4
8
2. IDL> print, 2 * 4
8
3. IDL> Print, 2*4
8
The PRINT routine prints the value of its argument into the IDL output log. Notice
that the argument is evaluated before it is printed, resulting in the number (8) being
output to the log window.
Note: IDL saves previously entered statements in a buffer, and these statements can be recalled to the
command line with the UP-DOWN arrow keys on most keyboards while cursor focus is at the command
line. The number of lines saved in the recall buffer can be changed in the Preferences for IDL.
In an IDL session, data (i.e. numbers and strings) is stored in what’s known as
variables. There are 3 basic types of IDL variables :
Any given variable in IDL also has a specific data type. There are 12 basic atomic
data types in IDL (seven different types of integers, two floating-point types, two
complex types, and a string) [Fig. 1-3]. The data type assigned to a variable is
Variables do not have to be declared in IDL, and the data type of a variable can be
determined by its usage. If a new variable is set equal to the sum of two integers,
then the new variable will also be an integer. For example, start by declaring a
scalar variable named “a” and set it equal to a value of (2) :
4. IDL> a = 2
5. IDL> b = 5.0
IDL provides the ability to perform an arithmetic operation on these two variables
and store the result in a new variable called “c” without having to first declare “c” :
6. IDL> c = a + b
The HELP routine is used to get information about the IDL session. In this case, use
the HELP routine to obtain information on the three variables declared thus far :
7. IDL> help, a, b, c
A INT = 2
B FLOAT = 5.00000
C FLOAT = 7.00000
Notice that when variables of different data types are combined in a single
expression, the result has the data type that yields the highest precision.
So far all of the work performed has been with scalar variables, but the real power of
IDL is in the fact that it’s an array-oriented language. For example, declare a
variable called “array” as an integer matrix with two dimensions of size 5 columns
So far we have executed two different routines from the IDL language library, PRINT
and HELP. There are 3 basic types of routines that can be used by executing
statements within the IDL language :
• Procedures
• Functions
• Executive Commands
For example, execute the following procedure, function, and executive command
statements at the IDL> command prompt (Note: “0” is the number zero) :
In order to view the value returned by the SYSTIME function into the variable “time”
the HELP procedure can be utilized :
The IDL output log should report that “time” is a variable of type string that is equal
to the current date/time in the format “DOW MON DD HH:MM:SS YEAR”.
There are also 2 different types of parameters that any given IDL routine can
accept :
• Arguments
• Keywords
In the examples above, only arguments were specified. Arguments are used to
pass information (e.g. data) to and/or from the IDL routine. Arguments are
positional in that the order in which they are passed dictates what the IDL routine
does with the information in the variable/value specified. Some or all of the
arguments for any given routine may be optional.
In contrast, keywords are always optional and can be specified in any order.
Keyword parameters are used to control the behavior of the IDL routine being
executed, or to specify a named variable into which a result will be placed. For
instance, to control the behavior of the HELP procedure so it returns information
about the amount of dynamic memory (in bytes) currently in use by the IDL session,
set the MEMORY keyword equal to one :
The MEMORY keyword is a binary behavioral parameter that is either “on” or “off”,
and this is controlled by setting the keyword to a value of 1 or 0, respectively. A
shortcut to setting a keyword “on” is available by preceding the variable with the
forward slash “/” character. In addition, keywords can be abbreviated to the
Some keywords are used to return results from a routine. For example, the OUTPUT
keyword to the HELP procedure can be used to place a string array containing the
formatted output of the HELP command into a named variable called “text” :
Finally, it is worth mentioning that you can view the IDL software documentation and
automatically jump to the index location of a specific keyword by executing the
question-mark character “?” followed by the keyword :
This will launch the IDL Online Help system and display the reference guide entry for
the HELP procedure.
• Two and three dimensional plots (line, scatter, polar, and histogram style)
• Surface representations
• Contours
• Image displays
• Mapping
• Volume visualizations
• Execute the statement for the appropriate procedure at the IDL> command
prompt
• Select “File > New > Visualization > iTool Name” from the IDLDE main menu
• Windows users can launch an iTool directly by selecting “Start > All Programs
> RSI IDL #.# > iTools > iTool Name”, and Macintosh users can launch an
iTool directly by double-clicking “/Applications/rsi/idl_#.#/iTool Name”.
In this case, launch the iPlot tool by executing the procedure iPlot at the IDL>
command prompt :
A splash screen will appear while the iTools system is launching. The first time the
iTools system is launched in any given session of IDL will always be the slowest since
the iTools need to be compiled from their ASCII text source code files found in the
“lib/itools/” subfolder of the IDL distribution (i.e. the user has access to the source
code for the entire iTools system). Once the iTools system is up and running a
separate window will come up entitled “IDL iPlot”. Feel free to minimize the IDLDE
window as the next steps of this exercise will involve the iPlot utility.
In the following exercise, the time-series data from the example data file
“time_series.txt” will be input into the iPlot utility. This example data file is located
in the “data” subfolder of the Quick Start directory :
• Windows: C:\RSI\IDL##\IDL_QS_Files\data\time_series.txt
• UNIX et al.: /usr/local/rsi/idl_#.#/IDL_QS_Files/data/time_series.txt
• Mac OS X: /Applications/rsi/idl_#.#/IDL_QS_Files/data/time_series.txt
There are a number of different ways to load data into an iTool, and probably the
easiest of these is to use the data input utilities built into the iTools system.
Once the user is finished running the ASCII Template wizard the IDL iTools Create
Visualization dialog will come up [Fig. 2-4].
This will bring up the iTools Insert Visualization dialog. This tool is used to select the
data that is used to create the line plot visualization. In this case, there is one
independent variable (X) contained in the field “time_series.TIME”, and 3 dependent
variables (Y) that can be plotted as a function of this time.
12. Click on the “time_series” item within the Data Manager panel and expand.
13. Select the “X” row in the lower left table and then double-click the
“time_series.TIME” field from the upper left window to insert the time-stamp
data as the independent variable [Fig. 2-5].
14. Select the “Y” row in the lower left table and then double-click the
“time_series.DATA1” field from the upper left window to insert the first data
measurement as the dependent variable [Fig. 2-5].
15. Once these selections have been made, press “OK”.
A simple line plot of the “Time” data (X axis) versus the “Data1” data (Y axis) will
appear within the IDL iPlot window [Fig. 2-6]. Notice that both the X and Y axes
have been automatically scaled to display the full data range of the respective
variables. Currently the size of the IDL iPlot window should be the default when it
was first launched, which makes it difficult to visualize the features within the line
16. From the IDL iPlot window menu select “Window > Zoom on Resize”.
17. Hit the maximize button in the upper-right hand corner of the window.
Figure 2-6: The IDL iPlot window displaying graphic of time-series data
Currently the line plot should be displayed with the default black color. Furthermore,
the iPlot tool should be in selection mode with the line plot automatically selected
(graphic will be surrounded by 8 small squares and highlighted with cyan color
markers). If the line plot is not selected simply click on the line in any location so it
appears as displayed in Fig. 2-6. In order to differentiate the line plot from the axes
(and the other data variables which will soon be plotted) change the color to red by
following these steps :
18. Right-click on the lineplot in order to see the standard iTools context menu.
19. Select “Properties…”.
20. Within the IDL iPlot: Visualization Browser window, click on the box to the
right of the “Color” property and select bright red [Fig. 2-7].
21. Once the desired change has been made, close the IDL iPlot: Visualization
Browser window.
Now that the line plot for the first dataset has been changed in color to red, the two
remaining dependent data variables can be imported an overplotted within the
existing visualization :
22. From the IDL iPlot window menu system, select “Insert > Visualization…”.
23. Select the “Y” row in the lower left table and this time double-click the
“time_series.DATA2” field from the upper left window to insert the second
data measurement as the dependent variable.
24. Once this has been accomplished, hit “OK”.
This will automatically insert a new lineplot within the existing data space and axes.
Once again the line is plotted with the default black color, so use the following steps
to change the color of this line to blue :
25. Select the new black line plot if it is not already (it should be selected by
default).
26. Right-click, select “Properties…”, and change the “Color” property to blue.
27. Close the IDL iPlot: Visualization Browser window.
Next, plot the third and final data variable and change its line color to green :
28. From the IDL iPlot window menu system, select “Insert > Visualization…”.
29. This time select the “Y” row in the lower left table and then double-click the
“time_series.DATA3” field from the upper left window to insert the second
data measurement as the dependent variable.
30. Once this has been accomplished, hit “OK”.
31. Select the new black line plot.
Notice that when this final data variable was plotted, the scaling of the Y axis
automatically changed in order to display the full data range of all 3 time-series
measurements. In addition, dashed lines that are cyan in color will be displayed
when a specific line plot is selected, which mark the minimum and maximum Y data
range for that dataset. The line plot visualization should now look like Fig. 2-8.
Now that all 3 time-series datasets have been loaded and plotted, it is a good idea to
save the current state of the iPlot visualization utility. When an iTool is saved, the
state of the utility in its entirety is output to a file on disk, and this state includes the
layout of the current graphical visualizations, their properties, and the data itself.
Use the following steps to save the current iTool state :
34. From the IDL iPlot window, select “File > Save As…”.
35. Save the iTools state to a new file named “line_plots.isv” located in the
“output” subfolder of the Quick Start directory [Fig. 2-9] :
• Windows: C:\RSI\IDL##\IDL_QS_Files\output\line_plots.isv
There are three ways to select separate or multiple objects within the iTools system :
If at any time an action is taken within an iTool that the user wishes to reverse, they
can utilize the built-in Undo/Redo system. There are two ways to access the
Undo/Redo mechanism within any given iTool :
7. Experiment with the Undo/Redo system using both the toolbar buttons and
the Edit menu system items in order to retrace and repeat the steps that
have been performed within the current IDL iPlot utility.
8. Using the Select/Translate arrow or the Undo/Redo system, setup the current
visualization in its previous appearance with the data space centered within
the view window.
9. While in Select/Translate mode, click in an area outside of the data space so
that no object appears selected.
10. Open the Visualization Browser window by selecting “Window > Visualization
Browser…” from the menu system.
11. Experiment with selecting various objects on the left-hand side of the
Visualization Browser window.
Currently the 3 line plot graphical objects that are contained within the iTool are
named “Plot”, “Plot 0”, and “Plot 1” by default [Fig. 2-10]. These line plot objects
can be given more appropriate names that help associate them with the data they
are displaying.
12. Click on the first line plot object named “Plot” within the Visualization Browser
window.
13. On the right-hand side, change the “Name” property to the appropriate time-
series field name from the original dataset “Data1”. It may help to expand
the plot object tree to look at the parameters (data) that define the graphical
object [Fig. 2-11].
14. Make sure to hit the Enter key on the keyboard after modifying the “Name”
property so the change takes effect.
15. Repeat this process for the other 2 line plot objects, changing “Plot 0” to
“Data2”, and “Plot 1” to “Data3” [Fig. 2-11].
16. The final state of the Visualization Browser window should look like Fig. 2-11.
Once this has been accomplished close the Visualization Browser window.
17. From the IDL iPlot window menu system, select “Edit > Select All”.
18. Click the Rotate button to enter rotation manipulator mode.
19. Experiment with arbitrarily rotating the current graphic by clicking on it,
holding down the mouse button, and moving the mouse.
Figure 2-11: Changing the Name properties of the 3 line plot objects
The size of the graphics area can also be made smaller / larger in relation to the
display canvas by using the View Zoom manipulator :
22. Click the Zoom button to enter View Zoom manipulator mode.
23. Position the mouse pointer over the viewplane. The pointer will change to a
zoom pointer.
24. The view zoom manipulator works by clicking-and-dragging with the mouse
cursor. Dragging the zoom pointer towards the top of the window (upwards
direction) will enlarge the graphics. Dragging the zoom pointer towards the
bottom of the window (downwards direction) will make the graphics area
smaller.
25. Restore the graphics area (approximately) to its original size, and click on the
Select/Translate arrow button in order to leave View Zoom mode.
In addition to using the View Zoom manipulator tool, the size of the graphics area
can also be made smaller / larger using the constrained and unconstrained scaling
available when using the Select/Translate arrow mode. Constrained scaling permits
changing the size of only one dimension while preserving the size of the other
26. While using the Select/Translate arrow mode, click on one of the line plots
within the graphics area.
27. In addition to the selected line plot being highlighted with cyan color markers,
the 8 green selection boxes will appear around the graphics area.
28. To perform constrained scaling, position the mouse cursor over one of the
four selection boxes found midway along each side of the graphics area. The
mouse cursor will change to a double-headed arrow.
29. Click-and-drag with the mouse to scale the graphics in the desired direction.
30. To perform unconstrained scaling, position the mouse cursor over one of the
four selection boxes found in the corners of the graphics area. The mouse
cursor will change to a four-headed arrow.
31. Click-and-drag with the mouse to scale the graphics in an unconstrained
fashion.
32. Restore the graphics area (approximately) to its original shape and size.
Finally, the Data Range tool allows the user to zoom into the data space itself,
instead of simply resizing the graphics area within the viewplane. This allows users
to adjust the range displayed within the current graphics area, and zoom into the
data space to get a better look at features at a smaller scale.
33. While one or all of the line plots are selected, click the Data Range button
to enter data range manipulator mode.
34. Both the X and Y axes will be labeled with green translation arrows and zoom
symbols (“+” and “-”). Clicking on these will change the range and location
of the respective axis.
35. In addition, position the mouse cursor within the graphics area containing the
line plots. The mouse cursor will change to a cross-hair.
36. Click-and-drag to define a rectangular box within the graphics area, and once
the box has been defined release the mouse button to zoom into the
corresponding data range.
37. Select/Translate arrow button in order to leave Data Range mode.
38. In order to reset the data range to the original full extent of all 3 data
variables, select “Window > Reset Dataspace Ranges” from the IDL iPlot
window menu system.
5. Next, select the second axis object named “Axis 2”. This selects the Y axis
along the left-hand side of the graphics area.
6. Find the “Tick direction” property, click within the setting box, and change the
droplist to “Left/Below”.
7. Once again, scroll down and change the “Title” property to “Data Values”.
8. Finally, select the last axis named “Axis 3” and change the “Tick direction”
property to “Right/Above”.
9. Once these tasks have been accomplished, close the Visualization Browser
window.
10. An axis may still be selected, so click in the white viewplane outside of the
graphics area to unselect all graphical objects.
It may also be appropriate to provide a title for the overall visualization, and this can
be inserted into the visualization using the Text annotation tool :
11. Click the Text annotation button to enter text insertion mode.
12. Once the mouse cursor is moved over the viewplane, the pointer will change
to a standard text selection cursor.
13. Click on a location outside and above the graphics area. A cursor is inserted
into the annotation layer and text insertion mode is initiated.
14. Using the keyboard, enter the text “Time-Series Line Plots”. Once finished
typing this text, hit the Enter key to complete the text annotation.
15. While this text annotation object is highlighted, right-click on it and select
“Properties…” from the context menu.
Finally, a legend can be inserted into the iPlot visualization window in order to label
the line plots with the names that were previously defined :
20. Click on one of the line plots, hold down the Shift key, and click on the
remaining two so that all 3 line plots are selected and highlighted.
21. From the menu system, select “Insert > New Legend”.
22. Position the legend in the desired location in the upper-right hand corner of
the viewplane.
23. Click in a blank white area of the viewplane outside all graphical objects in
order to deselect all objects.
24. At this point, it may be a good idea to re-save the current state of the iPlot
utility. This can be accomplished by selecting “File > Save” from the menu
system or hitting the Save button.
25. The current state of the IDL iPlot window should look similar to Fig. 2-13.
In the case of visualizing line plots of time-series data, one common operation that is
performed in signal processing analysis is the application of a smoothing filter that
will help eliminate some of the high-frequency noise contained within the data. In
addition, the user may be interested in obtaining mathematical statistics on the
time-series datasets :
In addition to the standard clipboard operations, the iTools system also offers the
ability to export the current visualization to a wide variety of generic image formats :
12. From the menu system, select “File > Export…”. This will launch the IDL Data
Export Wizard.
13. In Step 1 of 3, select the “To a File” option for the export destination and hit
the “Next >>” button.
14. In Step 2 of 3, the user can select individual graphical objects to specify
either the entire visualization or individual data items to export. In this case,
in order to output the entire visualization select the “Window” object and hit
“Next >>”.
15. In step 3 of 3 the output “File Type:” should be set to Windows Bitmap by
default. If this is not the case, select Windows Bitmap now.
16. Click the file selection button and specify an output filename of “plot.bmp”
within the “output” subfolder of the Quick Start directory [Fig. 2-15].
17. Once this is accomplished, hit the “Save” button in order to return to the IDL
Data Export Wizard.
• Windows: C:\RSI\IDL##\IDL_QS_Files\output\plot.bmp
• UNIX et al.: /usr/local/rsi/idl_#.#/IDL_QS_Files/output/plot.bmp
• Mac OS X: /Applications/rsi/idl_#.#/IDL_QS_Files/output/plot.bmp
Looking within the “output” directory for the bitmap file that was just exported from
the iPlot utility, the user should find a new file named “plot.bmp”. Looking at this file
in any standard image visualization software that can read and display bitmap files
will display the contents of the iPlot visualization as it currently appears.
The current iPlot visualization can also be sent directly to a printer for hardcopy
output :
20. Select “File > Print Preview…” from the main menu system.
A separate Print Preview window will be displayed [Fig. 2-16]. This tool allows the
user to control the layout of the iTools viewplane window in relation to a standard
8.5” x 11” piece of paper. Within the Print Preview window pane are horizontal and
vertical offset bars, along with a scaling box.
26. Once finished working with the Print Preview tool, press “Close”.
27. At this point, the IDL iPlot window containing the time-series visualizations
can be closed as it is no longer used from this point forward. This can be
accomplished by selecting “File > Exit” from the menu system or hitting the
Close button in the upper-right hand corner.
28. Restore the IDL Development Environment window so the IDL> command
prompt can be accessed.
The RANDOMU function returns two variables “x” and “y” that contain data values
ranging from 0 1.0 that are created by a random number generator. To visualize
these two vectors in a X-Y scatter plot, simply load the variables as arguments to
the IPLOT procedure and set the appropriate keywords in order to control the
properties of the plot object. In this example, the SCATTER keyword is set in order
to change the graphic style from the default line plot to scatter plot mode, the
SYM_INDEX keyword is set to the symbol index for small rectangular boxes, and the
COLOR keyword is set to a RGB triplet for the color red :
This will launch a new IDL iPlot window containing a X-Y scatter plot of the random
data values plotted as small red rectangles [Fig. 2-17].
4. It may help to click in the white viewplane outside of the graphics area to
deselect the scatter plot object in order to remove the cyan selection
markers.
Note: The appearance of the X-Y scatter plot that results may differ slightly from what appears in Fig. 2-
17 since the random numbers that are generated by the RANDOMU function will always be different.
5. Once finished viewing the X-Y scatter plot, close the IDL iPlot window.
The resulting IDL iPlot visualization window should look like Fig. 2-18.
8. Once finished viewing the histogram plot, close the IDL iPlot window.
So far all of the data that has been plotted is in a standard Cartesian (X-Y)
coordinate system. In some cases, the data may use a polar coordinate system,
which involves radius distances measured at various angles (theta) that are
expressed in units of radians. For example, create a vector named “theta” that
stores angles which encompass a full 360 degrees in 15° increments, and create a
vector named “radius” that contains distances which range from 0 24 :
The resulting IDL iPlot visualization window should look like Fig. 2-19.
12. Once finished viewing the polar plot, close the IDL iPlot window.
Finally, the iPlot utility is not limited to two dimensions, and quite often it is
necessary to visualize datasets that have 3 variables (X, Y, Z) in three dimensions.
For example, consider the flight test data that is stored in the file “flight_test.txt”.
This example data file is located in the “data” subfolder of the Quick Start directory :
• Windows: C:\RSI\IDL##\IDL_QS_Files\data\flight_test.txt
• UNIX et al.: /usr/local/rsi/idl_#.#/IDL_QS_Files/data/flight_test.txt
• Mac OS X: /Applications/rsi/idl_#.#/IDL_QS_Files/data/flight_test.txt
The file “flight_test.txt” contains standard ASCII text consisting of 3 columns of data
separated by whitespace. The first column contains longitude location in units of
decimal degrees, the second column contains latitude position, and the third column
contains the altitude of the aircraft. Here are the first 2 lines of this ASCII text file :
This flight test data will be loaded into a new iPlot utility in the same manner as the
time-series data that was used in the previous exercise. Start by launching a new
blank IDL iPlot window :
Figure 2-20: Specifying the parameters for the 3-D line plot
The resulting IDL iPlot window should look like Fig. 2-21.
All of the same translation, rotate, zoom, and scaling manipulators are available
within the iTools system when a 3-Dimensional graphic is displayed, although they
act in three dimensions.
22. Once finished viewing the 3-Dimensional line plot, close the IDL iPlot window.
23. Before moving on to the next chapter, it is a good idea to reset the IDL
session. This can be accomplished by executing the statement :
IDL> .reset_session
• Windows:
C:\RSI\IDL##\IDL_QS_Files\data\Grand_Canyon_DEM.tif
• UNIX et al.:
/usr/local/rsi/idl_#.#/IDL_QS_Files/data/Grand_Canyon_DEM.tif
• Mac OS X:
/Applications/rsi/idl_#.#/IDL_QS_Files/data/Grand_Canyon_DEM.tif
Although the file “Grand_Canyon_DEM.tif” is in TIFF image format, the pixels of this
dataset contain actual elevation data values in units of meters. Use the following
steps to load this dataset into the iContour utility :
1. IDL> iContour
2. Select “File > Open…” from the IDL iContour window.
3. Select the “Grand_Canyon_DEM.tif” file and hit “Open”.
4. A contour graphical object with the default properties will be automatically
inserted into the IDL iContour window.
5. It may help to maximize the iTool window in order to see the graphic, so
select “Window > Zoom on Resize” from the menu system and maximize the
IDL iContour window.
6. Select the contour plot object, right-click, and select “Properties…”.
7. Within the Visualization Browser window, click on the box to the right of the
“Levels color table” property and select “Edit…” [Fig. 3-1].
8. A separate dialog entitled Palette Editor will be displayed. In the “Load
Predefined…” droplist, select the “RAINBOW” color table.
9. Press “OK” to dismiss the Palette Editor window.
10. At this point the IDL iContour window will be brought to the foreground.
Relocate the Visualization Browser window, which may be behind the IDL
iContour window. Change the “Number of levels” property to a value of “10”,
hit Enter on the keyboard to complete the change, and close the Visualization
Browser window [Fig. 3-1].
The DEM data for the Grand Canyon should now be displayed with a sequence of
color contours that resembles a topographic map. The elevation at which the
The iTools system also have built-in tools for inserting a colorbar and legend for a
contour plot graphic :
The final IDL iContour window should appear like Fig. 3-2.
15. Once finished viewing the contour plot visualization, close the IDL iContour
window.
In the following exercise, the X-Y-Z data from the example data file “elevation.txt”
will be input into the iSurface utility. This example data file is located in the “data”
subfolder of the Quick Start directory :
The file “elevation.txt” contains standard ASCII text consisting of 3 columns of data
separated by commas. The first column contains the longitude position, the second
column contains latitude, and the third stores the elevation data values. Here are
the first 2 lines of this ASCII text file :
Longitude,Latitude,Elevation
-136.049,59.3303,3537
Use the following steps in order to load the data from the file “elevation.txt” into the
iSurface utility :
After the IDL Gridding Wizard is completed, the selected gridding and interpolation
algorithm is used to convert the unstructured X-Y-Z data into a 2-Dimensional grid.
Once this processing is finished, a surface object for the elevation data will be
displayed within the IDL iSurface window [Fig. 3-6]. At this point, it may be
beneficial to maximize the iSurface utility :
33. From the IDL iSurface window menu system, select “Window > Zoom on
Resize”.
34. Maximize the IDL iSurface window.
• Constrained Scaling
o Multiple-Axis Scaling ( mouse pointer)
o Single-Axis Scaling ( mouse pointer)
• Unconstrained Scaling ( mouse pointer)
The multiple-axis scaling mouse pointer for 3-D objects is obtained when the
mouse pointer is positioned over a corner of a 3-D object’s data space. Dragging the
constrained scaling pointer scales the object a fixed distance along all axes in the
1. Experiment with the 3 different styles of scaling with the 3-D surface object
within the IDL iSurface window.
2. Use the single-axis constrained scaling along the Z-dimension whisker to
adjust the vertical exaggeration of the surface object. It may be appropriate
to reduce the vertical exaggeration in order to make a more realistic
visualization of the terrain.
3. If at any time an undesirable scaling operation is performed, remember that
the Undo tool can be used to reverse the operation.
The rotation of 3-D objects in the iTools system can be done in a freehand
(unconstrained) fashion or constrained along each of the three orthogonal axes.
When a 3-D object is selected within rotation mode, a rotation sphere consisting of
circular X, Y, and Z dimension axes is displayed around the object. To rotate an
object in a constrained fashion, position the mouse cursor over one of the three axis
circles in the rotation sphere until the cursor changes to a constrained rotation
pointer and drag in the desired direction. To rotate an object in an freehand fashion
simply position the mouse pointer anywhere on the object until the cursor changes
to an unconstrained rotation pointer and drag in any arbitrary direction.
4. Experiment with both constrained and freehand rotation of the 3-D surface
object.
1. Using the Select/Translate arrow, select the surface object within the IDL
iSurface window.
2. While the surface object is highlighted, select “Operations > Contour” from
the menu system. The Contour dialog will appear [Fig. 3-7].
3. Within the Contour dialog, change the “Number of levels” parameter to “20”
[Fig. 3-7].
4. Click in the box to the right of “Projection” parameter and change its setting
to “Three-D” [Fig. 3-7].
5. Once these changes have been made, press the “OK” button. This will insert
the contour graphical object within the same iSurface utility as the existing
surface object.
In order to get a better view of these contours, it may be beneficial to change their
color so it contrasts with the surface.
In addition to the ability to drape contours on top of a surface, IDL also has the
capability to drape images on top of 3-Dimensional graphical objects. This
visualization technique involves the use of what’s known as a texture map.
The example “data” subfolder of the Quick Start directory contains a PNG image file
of a satellite image that covers the same exact area as the elevation data :
• Windows: C:\RSI\IDL##\IDL_QS_Files\data\satellite.png
• UNIX et al.: /usr/local/rsi/idl_#.#/IDL_QS_Files/data/satellite.png
• Mac OS X: /Applications/rsi/idl_#.#/IDL_QS_Files/data/satellite.png
This image can be draped on top of the surface as a texture map using the following
steps :
10. First, remove the contours so they will not hinder the display of the texture
map image. This can be accomplished by opening the Visualization Browser,
right-click on the Contour object, and select “Delete”.
11. Close the Visualization Browser window.
12. Within the IDL iSurface window select the surface object, right-click, and
select “Parameters…”.
13. From the Parameter Editor window, press the “Import File…” button. This will
launch the File Import dialog.
14. Within the File Import dialog, press the file selection button, navigate to
the appropriate location, select the file “satellite.png” and hit “Open”.
15. Once this file is selected, the File Import wizard should recognize the format
as being “Portable Network Graphics”.
16. Hit “OK” to dismiss the File Import dialog.
17. Back within the Parameter Editor, expand the new “satellite.png” image item
so the “Image Planes” contained within are visible. This image is in 24-bit
RGB true color mode, so it has 3 image planes.
18. Select the “Texture” row located in the lower-left table, and then double-click
the “Image Planes” from the Data Manager in the upper-left corner of the
window in order to load this image as the surface’s texture map [Fig. 3-9].
19. Once this is accomplished, press “Apply” followed by “Dismiss” to complete
the changes.
20. Once finished viewing the surface visualization, close the IDL iSurface utility.
21. Before moving on to the next chapter, it is a good idea to reset the IDL
session. This can be accomplished by executing the statement :
IDL> .reset_session
In the following exercise, the image data from the example data file “MRI.dcm” will
be input into the iImage utility. This example data file is located in the “data”
subfolder of the Quick Start directory :
• Windows: C:\RSI\IDL##\IDL_QS_Files\data\MRI.dcm
• UNIX et al.: /usr/local/rsi/idl_#.#/IDL_QS_Files/data/MRI.dcm
• Mac OS X: /Applications/rsi/idl_#.#/IDL_QS_Files/data/MRI.dcm
The file “MRI.dcm” is in DICOM format, which is the industry standard for storing
imagery and diagnostic patient information in the radiology community. This file
contains a grayscale (black-and-white) image of a MRI exam involving a single slice
through a human brain. The MRI image can be loaded into the iImage utility using
the following steps :
16. From the IDL Development Environment window, select “File > New >
Visualization > iImage”. A separate IDL iImage window will appear.
17. Click on the open file button on the toolbar of the IDL iImage window.
18. Select the “MRI.dcm” file and hit “Open”. An image graphical object will be
automatically inserted into the utility.
Along the right-hand side of the iImage utility is a panel that is not present on the
other iTools utilities. This panel contains cursor query, histogram manipulation, and
ROIs (Regions Of Interest) tools specific to the image graphical object.
19. While the image object is selected and the iTool is in Select/Translate arrow
mode, move the mouse cursor over the image and watch the “Pixel Location:”
and “Pixel Value:” fields update.
The origin location for the image (0,0) is considered to be the pixel in the lower-left
hand corner. Within the “Pixel Value:” field there is actually 2 numbers displayed:
the first being the actual image data pixel value, and the second within parentheses
is the scaled display value [Fig. 4-1]. Since the computer monitor can only display
256 (or sometimes less) levels of discrete brightness for each color channel, all
image data is scaled to fit within the range of 0 255 automatically by the iImage
utility if it does not already. The “Min:” and “Max:” fields within the Image panel
Figure 4-1: The iImage utility displaying a MRI image of a human brain
The Image panel also displays a small histogram (density) plot of the pixel data
values displayed on its side [Fig. 4-1]. The histogram plot ranges from the minimum
pixel data value on the bottom to the maximum pixel value on the top. Since the
current image is dominated by very dark pixels (i.e. the black area around the
border), the scaling of this histogram is skewed and difficult to visualize in such a
small display window. Fortunately, the iTools system has a built-in operation for
creating a separate iPlot utility that displays the density distribution for data objects
using a histogram plot.
A separate IDL iPlot window appears, and the histogram density plot for the image is
displayed in a more robust fashion. Notice that most of the pixels in the image
(more than 40,000) have a very low (dark) data value.
22. Once finished viewing the image histogram, close the separate IDL iPlot
window.
23. Click on the green maximum image stretch bar and move it down within the
histogram plot window. Notice how the “Max:” field within the Image panel
updates with the selected pixel data value, and the image display is
automatically updated based on the stretch modification.
24. Click on the red minimum image stretch bar and move it up within the
histogram plot window.
25. Finally, click on the black range location bar and move it up and down to re-
position the current image stretch.
26. Once finished experimenting with the histogram manipulation tool, reset the
stretch to its original state by moving the green and red bars to the top and
bottom of the window, respectively.
The Image panel within the iImage utility also has built-in regions of interest (ROI)
tools that can be used to specify certain areas within an image for processing and
analysis.
27. While the image object is selected, click on the freehand ROI definition
button to enter into ROI definition mode.
28. Once the mouse cursor is positioned over the image object it will change to
the ROI definition pencil pointer. Click-and-drag with the mouse to draw a
ROI on top of a feature within the MRI image. When the mouse button is
released the ROI definition will complete to a solid polygon, and the new ROI
will be highlighted with small green boxes.
Once the ROI definition is complete, the object can be resized and moved by clicking
on or within the green highlight boxes. Now that a region of interest has been
defined, the user can obtain useful information about the image pixels contained
within the region such as statistics :
29. While the ROI object is highlighted, select “Operations > Statistics…” from the
menu system.
A separate dialog entitled “Display statistics for the selected item” will appear, which
lists useful statistical information on the image data contained within the region of
interest [Fig. 4-2].
Note: The exact statistical information that is reported will vary from what appears in Fig. 4-2 since the
ROI is drawn in an arbitrary fashion.
30. Once finished viewing the statistical information, close the “Display statistics
for the selected item” dialog.
31. While the ROI object is selected and highlighted, right-click on it and select
“Delete” in order to remove it from the current visualization.
1. Select the image, then press the “Edit Palette…” button on the Image panel.
2. A separate Palette Editor dialog will appear. Within this window press the
“Load Predefined…” droplist and select the “BLUE/GREEN/RED/YELLOW” color
palette.
3. Press “OK” to dismiss the Palette Editor dialog.
Instead of displaying the image with the input Black Gray White color palette,
the IDL iImage utility is now applying the selected color table and displaying the
image brightness values through the color range of Black Blue Green Red
Yellow. This allows the user to visualize the features within the image in color and
4. Experiment with moving the green, red, and black stretch manipulation bars
on the image histogram once again to see the effect the new color palette has
on the image display.
5. Once finished experimenting with the histogram manipulation tool, reset the
stretch to its original state by moving the green and red bars to the top and
bottom of the window, respectively.
At this point it may be useful to insert a colorbar into the current visualization so the
user can see how the input image pixel data range maps to the colors that are
displayed.
6. Make sure the image object is selected, and from the menu system select
“Insert > Colorbar” [Fig. 4-3].
7. Make sure the image object is highlighted and select “Operations > Filter >
Smooth” from the menu system.
This operation will apply a smoothing image filter, which helps to remove unwanted
noise using a weighted average. Notice how the image histogram and colorbar
automatically update based on the image that is returned from this operation.
9. Select “Operations > Filter > Sobel Filter” from the menu system.
The Sobel filter operation uses the Sobel edge enhancement algorithm to detect and
highlight edges within the image.
10. Finally, select “Operations > Morph > Morph Open” from the menu system.
11. Within the Morph Open dialog, leave all parameters set to their default values
and simply press the “OK” button.
The opening morphological operator removes noise from an image while maintaining
the overall sizes of objects in the foreground. The resulting visualization should look
similar to Fig. 4-4.
Figure 4-4: The result of applying Smooth, Sobel and Morph Open operations
12. Once finished viewing the MRI image visualization, close the IDL iImage
window.
• Windows: C:\RSI\IDL##\IDL_QS_Files\data\nebula.jpg
• UNIX et al.: /usr/local/rsi/idl_#.#/IDL_QS_Files/data/nebula.jpg
• Mac OS X: /Applications/rsi/idl_#.#/IDL_QS_Files/data/nebula.jpg
The file is in JPEG format and contains an image of the famous Ring Nebula taken by
the Hubble Space Telescope. In contrast to the single channel MRI image used in
the last exercise, this dataset is a 3 channel (Red, Green, Blue) 24-bit true color
image. In this case, the three color channels are displayed together in order to
visualize the color image. Use the following steps to load the “Nebula.jpg” image
into a new iImage utility :
1. IDL> iImage
2. Click on the open file button on the toolbar of the IDL iImage window.
3. Select the “Nebula.jpg” file and press “Open”.
The color image be automatically displayed within the IDL iImage window.
4. Move the mouse cursor over the image and notice how the “Pixel Value:” field
in the Image panel is now reporting 3 pixel values: one each for the R (red),
G (green), and B (blue) image channels that are combined together to make
the color display.
In this case, the image data values already fall within the display range of 0 255,
so no scaling is needed.
The iImage utility has a built-in line profile tool that will plot image pixel values along
a user-defined transect. This tool will automatically launch a secondary iPlot utility
containing line plots for the pixel values along the selected line for each of the three
red, green, and blue image channels.
5. While the image object is selected, click on the line profile button on the
toolbar.
Once the mouse cursor is positioned over the image object it will change to the line
profile pointer. In order to define a line profile, the user must left-click at the
desired starting location for the transect, hold down the mouse button, drag to the
desired ending location for the transect, and release the mouse button in order to
complete the profile. Once this is accomplished a separate iPlot utility will be
launched containing the 3 line profiles (one for each color channel).
6. Using the mouse, click-and-drag from the upper-right hand corner of the
image to the lower-left hand corner.
The resulting IDL Line Profile window should look similar to Fig. 4-5.
7. Once finished viewing the line profiles, close the IDL Line Profile window.
8. To remove the line from the current visualization, click on it and press the
Delete key on the keyboard.
Since image data is actually a gridded 2-Dimensional array of pixel values, it can
also be visualized using some of the other graphical objects available in the iTools
system. For example, it is quite easy to insert a contour plot into the existing utility
in order to make a composite visualization.
In addition to the analysis capabilities exposed within the iTools system under the
Operations menu, the IDL library includes hundreds of routines that provide
advanced processing capabilities. Some of these processing algorithms are very
specialized, and it is not appropriate to place an item within the Operations menu in
the iTools system to run all of these more advanced tools. Fortunately, the iTools
system was designed in a manner that allows the user to easily pass data back-and-
forth between an iTool utility and the IDL> command prompt.
In the following exercise, the green channel for the current image will be exported
from the iImage utility to the IDL> command prompt level within the IDL
Development Environment for specialized processing. First, the green channel image
will be smoothed using the SMOOTH function in an effort to minimize noise. Then,
the WATERSHED function from the IDL library will be used to segment the image into
watershed regions and their boundaries. The watershed algorithm considers the
grayscale image as a surface, where each local minimum can be thought of as the
point to which water falling on the surrounding region drains. The boundaries of the
watersheds lie on the tops of the ridges. This operator labels each watershed region
17. From the IDL iImage window menu system, select “File > Export…”.
18. In Step 1 of 3 for the IDL Data Export Wizard, select “To an IDL Variable” and
hit “Next >>”.
19. In Step 2 of 3, expand the object hierarchy tree until the green image plane
“Channel 1” can be selected [Fig. 4-7].
Figure 4-7: Selecting the green channel image for export to IDL
20. Press “Next >>”, and within Step 3 of 3 leave the “IDL Variable Name:” field
set to the default “Channel_1” and hit “Finish”.
21. Bring-up the IDL Development Environment window so the IDL> command
prompt can be accessed. Execute the following statements at the IDL>
command prompt.
22. IDL> HELP, Channel_1
This will report to the output log that a 2-Dimensional byte array with the same
spatial size as the Ring Nebula image loaded into the iImage utility now exists within
IDL’s main memory space :
This is a duplicate copy of the same data that is stored in the iImage utility, so it can
be acted upon in a manner independent of the image that is currently being
displayed. Now execute the advanced watershed analysis :
Once this is accomplished, a new variable named “segmented” exists at the main IDL
level which contains the resulting watershed image. This new image can be loaded
into the existing iImage utility and compared to the original image using the
following steps :
25. From the IDL iImage menu system, select “Window > Layout…”. This will
bring-up a separate dialog entitled “Window Layout” [Fig. 4-8].
26. Within the Window Layout dialog, change the “Columns:” field to “2” and hit
Enter on the keyboard. The Preview pane will update to show the new
viewplane which will be inserted into the existing iImage utility [Fig. 4-8].
Figure 4-8: The Window Layout tool within the iTools system
The watershed analysis has segmented the image into discrete regions, which are
currently being displayed with the default grayscale color palette. It is more
effective to visualize this watershed image using one of IDL’s built-in color tables.
34. Select the new watershed segmentation image and press the “Edit Palette…”
button.
35. Within the Palette Editor dialog click on the “Load Predefined…” droplist and
select the “Rainbow + white” color table.
36. Press “OK” to dismiss the Palette Editor dialog.
37. Once finished viewing the two images, close the IDL iImage utility.
38. Before moving on to the next chapter, it is a good idea to reset the IDL
session. This can be accomplished by executing the statement :
IDL> .reset_session
In the following exercise, volumetric data of numerous image slices from the Visible
Human project stacked together will be visualized using the iVolume utility. This
volume consists of seventy 128 x 128 image slices acquired through the torso of a
human body. This example data is stored in a file named “torso.dat” that is located
in the “data” subfolder of the Quick Start directory :
• Windows: C:\RSI\IDL##\IDL_QS_Files\data\torso.dat
• UNIX et al.: /usr/local/rsi/idl_#.#/IDL_QS_Files/data/torso.dat
• Mac OS X: /Applications/rsi/idl_#.#/IDL_QS_Files/data/torso.dat
The “torso.dat” file does not have any particular file format, and the data is stored
within this file in a flat binary fashion. Consequently, the user will be required to
provide IDL with the information it needs in order to successfully read the data from
the file on disk. Use the following steps to load this dataset into the iVolume utility :
1. IDL> iVolume
2. Select “File > Open…” from the IDL iVolume window.
3. Within the Open dialog, change the “Files of type:” droplist to “All files (*)”.
4. Select the “torso.dat” file and hit “Open”.
The dialog for the Binary Template wizard will appear. This wizard helps walk the
user through the steps of providing IDL with information on the structure of the
binary file so the data can be read into the iVolume utility. The user must provide
the following basic information in order for the data to be successfully input :
• Number of dimensions
• Size of each dimension
• Data type
• Offset (size of header)
• Byte order (Little Endian or Big Endian)
Without this information, there is no way for the software to know how to read-in the
binary data from the file on disk.
5. Start by pressing the “New Field…” button within the Binary Template wizard.
6. Within the New Field dialog, set the “Field name:” parameter to the string
“torso” [Fig. 5-1].
7. The data type for this volumetric dataset is unsigned 8-bits (Byte), so the
“Type:” droplist can be left as its default setting [Fig. 5-1].
8. The selected data file does not contain a header, so the “Offset:” parameter
can be left as its default “>0” setting [Fig. 5-1].
9. The volumetric dataset has three dimensions, so set the “Number of
dimensions:” droplist to “3” [Fig. 5-1]. Once this is accomplished, the “Size:”
text boxes for the 1st, 2nd, and 3rd dimensions will become active.
10. The seventy images are stored within this volume using an interleave known
as band-interleaved by line (BIL). Consequently, the dimensions of the 3-D
array are 128 x 70 x 128 [Fig. 5-1].
11. Once these settings have been completed, press “OK” to dismiss the New
Field dialog.
Figure 5-1: The New Field dialog within the Binary Template wizard
The user will be returned to the Binary Template wizard, which will show the
parameters for the “torso” field definition that was just created [Fig. 5-2].
Once the Binary Template wizard is finished a 3-Dimensional volume object will be
automatically inserted into the IDL iVolume utility. By default, the data space and
axes will be shown, but the volume itself will not be rendered.
There are a number of ways to visualize volumetric data within the iVolume utility.
Of course, the individual image planes that were stacked up to create the volume
can be extracted and viewed in each of the three (X-Y, Y-Z, and X-Z) orthogonal
planes. A technique known as isosurfacing can be used to contour the data, which
creates a surface that shows the voxels in the 3-D data space that all have a
specified data value (the isovalue). In addition, an interval volume can be
extracted which is a tetrahedral mesh that spans the 3-D data space between two
isosurfaces created at different data values. Finally, true volume rendering can be
performed, which maps the voxel data elements to colors and opacity values through
a set of lookup tables, then projects the 3-D volume to a two-dimensional graphical
visualization. By default, the volume object within the iVolume utility is setup to
perform volume rendering.
14. While the data space is selected, click on the “Render” button within the
Volume panel on the right-hand side of the iVolume utility.
A volume rendering of the 3-Dimensional array is created using the default color
palette (grayscale) and opacity settings. The reason the iVolume utility forces the
user to press the “Render” button in order to visualize the object is because the
volume rendering process of very large datasets can be very computationally
intensive. In most cases, it is not feasible to constantly render the volume object
when any of the standard iTools manipulators (Translate, Rotate, Zoom, etc.) are
15. Using the Select/Translate arrow button, click on the data space and
move it slightly in one direction within the viewplane. The volume rendering
of the object disappears.
Since the current volumetric dataset is relatively small, the Auto-Render option can
be turned on so the iVolume utility will automatically update the visualization after
every action.
16. Click on the small white checkbox to the left of the Auto-Render option to
enable the auto-rendering capability.
Now the volume will be constantly rendered while object manipulations are being
performed.
1. From the IDL iVolume menu system, select “Window > Visualization
Browser…”.
2. On the left-hand side of the Visualization Browser window, select the “Data
Space” object [Fig. 5-3].
3. In the Data Space property sheet, click on the box to the right of the
“Isotropic scaling” property and set the droplist to “Isotropic” [Fig. 5-3]. The
volume object within the iVolume utility will automatically update and display
the data space in an isotropic fashion.
4. Close the Visualization Browser window.
The data space is now displayed in an isotropic fashion and the length of each of the
three X-Y-Z axes is proportionate to their size.
There are two rendering qualities available for the volume object visualization :
The Boundary option displays an internal translucent solid cube within the data
space, which is useful when the volume is not automatically rendered so that the
user can locate and select the volume when no graphic is visible. Since the Auto-
Render option is currently enabled, there is no need to display the boundary.
1. Change the Quality droplist to “High (volume)” and the Boundary droplist to
“None”. Notice the effect these changes have on the volume rendering
visualization [Fig. 5-4].
Once the rendering quality is set to high, the Render Step “X:”, “Y:”, and “Z:” fields
will become sensitive, which allow the user to specify the stepping factor (in screen
dimensions) through the voxel matrix [Fig. 5-4]. By default, these fields are set to
“1” so that each and every voxel is considered when the volume is rendered.
Changing this setting to “2” would render only half as many voxels in the specified
screen dimension.
It is much quicker and easier to modify the other properties of the volume
visualization when the Auto-Render functionality is turned off. Once the desired
changes have been made, the “Render” button can be pressed in order to display the
visualization of the volume dataset.
The opacity lookup table controls the transparency of any given voxel, while the
current color palette defines what color is applied based on the voxel’s data value.
Manipulation of the color palette and opacity table is critical to controlling and
improving the appearance of a volume rendering.
Next, the opacity table can be modified in order to control the transparency effect
that is applied during the volume rendering. The Palette Editor dialog contains a
number of items [Fig. 5-5] :
• Reference colorbar along the top illustrating data value range increasing
from left-to-right using a grayscale ramp.
• Current palette colorbar that displays the currently loaded color table being
applied to the visualization.
• Channel display window, which contains line plots for the individual red,
green, and blue color palette channel vectors, along with a purple line for the
Alpha channel (opacity lookup table).
• Cursor location/value window.
• View and edit tools, including zoom options, color space, editing operations,
and channel selection.
The user can use the mouse cursor within the channel display window to modify the
selected channels by interactively drawing the desired lookup table curve. The 3
color channel vector line plots are displayed with increasing brightness from bottom-
to-top, and the combination of these 3 vectors creates the “Rainbow + white” color
table that was just loaded. Since the R, G, B color channels have already been set to
the desired color palette in the previous step, there is no need to modify or visualize
these channels.
6. At the bottom of the Palette Editor window, un-check each of the R, G, B color
channels in both the “Display” and “Modify” rows [Fig. 5-5].
Current
Palette
Colorbar
Channel
Display
Window
Cursor
Location/
Value
Window
View and
Edit Tools
Figure 5-5: The Palette Editor dialog with a gaussian distribution curve for
the alpha (opacity) channel
Now that all of the boxes under the R, G, B color channels are un-checked, only the
Alpha channel (A) is displayed with the purple line plot. This is a plot of the lookup
table for the current opacity effect, ranging from 0% opaque (100% transparent) at
the bottom of the channel display window to 100% opaque (0% transparent) at the
top. By default, the current opacity lookup table is a straight ramp from minimum
data value (left-hand side) to maximum data value (right-hand side). This straight
line has a slope of 1, meaning that the volume is rendered in a progressively more
7. Using the mouse cursor, click-and-drag within the channel display window
and draw a standard gaussian shaped distribution curve [Fig. 5-5].
8. Click on the “Smooth” button a few times to give the line a smoother
appearance if necessary.
9. Once the desired curve has been drawn, click “OK” to dismiss the Palette
Editor dialog.
Creating a gaussian shaped curve for the opacity lookup table has the effect of
highlighting (i.e. making more opaque) those voxels within the volume that have a
medium data value around the middle of the overall data range.
10. Press the “Render” button in order to display the volume visualization.
Figure 5-6: The volume rendering using a gaussian curve for the opacity
There are a number of other properties for the volume object that can be modified in
order to control the appearance and quality of the visualization. By default, when
rendering a volume object to the screen the voxel values that are selected to
compute the visualization properties are selected using nearest neighbor selection
11. If the Visualization Browser window is not still visible, select “Window >
Visualization Browser…”. Within the Visualization Browser window, scroll
down and change the “Interpolation” property for the Volume object to
“Trilinear”.
12. Press the “Render” button in order to display the volume visualization.
The rendering of the volume object should visually improve. When a volume is
rendered, gradients within the volume are used to approximate a surface normal for
each voxel, and the lighting sources in the current visualization are then applied to
illuminate the object. Gradient shading can be enabled by modifying the “Use
lighting” property. Furthermore, both sides of the voxels can be lighted by changing
the “Voxel gradient” property.
13. Change the “Use lighting” property to “True” and the “Voxel gradient”
property to “Two-sided”.
14. Press the “Render” button in order to display the volume visualization.
Figure 5-7: The rendering of the volume object with modified properties
By default, the volume object is rendered using the color palette and opacity table in
a composite function technique known as Alpha blending. In Alpha blending, each
15. Within the Visualization Browser window, change the volume object’s
“Composite function” property to “Maximum intensity projection”.
16. Press the “Render” button in order to display the volume visualization.
The volume object rendering will change to display a MIP of the volume based on the
current orientation of the 3-D data space. The resulting visualization should look
similar to Fig. 5-8.
17. Once finished viewing the MIP visualization, revert the setting for the
“Composite function” property back to the default “Alpha blending” and close
the Visualization Browser window.
1. While the volume object is selected, use “Operations > Volume > Image
Plane” to insert a new image object into the existing data space.
A cyan color rectangular box outlining the default image plane oriented in the Y-Z
direction and located in the exact center of the volume is inserted. The user can
click on this cyan box to move the location of the image plane within the current
orientation, and the center voxel location for the image plane is displayed in the
lower-right hand corner of the IDL iVolume window. For more advanced
modifications to the image plane, the Visualization Browser must be utilized.
The iVolume utility also has the ability to display a subvolume within the current
data space. This allows the user to specify a subset of the 3-Dimensional array to
use when rendering the volume object.
9. Click “OK” to dismiss the SubVolume Extents Selector dialog and close the
Visualization Browser window.
10. Press the “Render” button in order to display the volume visualization.
The subvolume extent will be rendered instead of the full 3-Dimensional dataset.
Finally, the volumetric dataset can be contoured in order to highlight all of the voxels
that have the same specific data value. These voxels are highlighted with a planar
object called an isosurface that is automatically loaded into the existing data space.
11. While the subvolume object is selected, use the “Operations > Volume >
Isosurface” menu item to launch the Isosurface Value Selector tool [Fig. 5-
11].
12. Use the mouse to drag the red data value selector line until the number “95”
appears in the text box.
13. Press the “OK” button to dismiss the Isosurface Value Selector tool.
The isosurface is computed for the volume and a new graphical object is inserted into
the iVolume utility. The resulting visualization should look similar to Fig. 5-12.
IDL> .reset_session
• The values of the signal are only measured at discrete points in time as a
result of sampling. In general most signals have a constant sampling
interval.
• The signal can take only discrete values as defined by the dynamic range of
the instrument and the precision at which the data is stored on the computer.
Curve Fitting
The problem of curve fitting can be summarized as follows :
Given a tabulated set of data values {xi, yi} and the general form of a mathematical
model (i.e. a function f(x) with unspecified parameters), determine the parameters
of the model that minimize an error criterion.
In the following exercise, the signal data from the example data file “curve.csv” will
be input into the current IDL session using the Import ASCII macro. This example
data file is located in the “data” subfolder of the Quick Start directory :
The file “curve.csv” is standard ASCII text containing 2 columns of data that
represent 2 variables (“x” and “y”). This ASCII text file uses comma-separated
values as the file format, which can be easily viewed in spreadsheet form within
Microsoft Excel.
1. From the main IDL development environment window, select “Macros >
Import ASCII”.
2. Within the file selection dialog choose the “curve.csv” file and hit “Open”.
This will launch the standard ASCII Template wizard which was used in previous
exercises to load data into the iTools system.
3. Within Step 1 of 3, make sure to change the “Data Starts at Line:” field to 2
and hit “Next >>”.
4. In Step 2 of 3 all settings can be left as their defaults, so simply hit “Next
>>”.
5. In Step 3 of 3, change the “Name:” of FIELD1 and FIELD2 to X and Y,
respectively.
6. Once this is accomplished, press “Finish”.
Once the ASCII Template wizard has finished running the user will be returned to the
main IDL development environment window where a new structure variable named
“curve_ascii” now exists. This variable stores the data that was input from the file,
and the HELP procedure can be used to acquire information on this variable :
The POLY_FIT function within IDL performs a least-squares polynomial fit with
optional error estimates and returns a vector of coefficients. The POLY_FIT function
uses matrix inversion. A newer version of this routine, SVDFIT, uses Singular Value
Decomposition (SVD), which is more flexible but slower. Another version of this
routine, POLYFITW, performs weighted least-squares fitting. In addition, the
CURVEFIT function uses a gradient-expansion algorithm to compute a non-linear
least squares fit to a user supplied function with an arbitrary number of parameters.
The user supplied function may be any non-linear function where the partial
derivatives are known or can be approximated.
Using the tabulated polynomial data now stored in the “curve_ascii” variable, use the
POLY_FIT fitting algorithm to fit a 3rd degree polynomial to the points :
The resulting IDL iPlot visualization window should look similar to Fig. 6-1.
Notice that POLY_FIT returns a vector containing the 4 estimated coefficients for the
3rd degree polynomial :
Start by creating a test signal that can be used for analysis. An IDL batch file called
“test_signal.pro” has been supplied within the “lib” subfolder of the Quick Start
directory :
• Windows: C:\RSI\IDL##\IDL_QS_Files\lib\test_signal.pro
• UNIX et al.: /usr/local/rsi/idl_#.#/IDL_QS_Files/lib/test_signal.pro
• Mac OS X: /Applications/rsi/idl_#.#/IDL_QS_Files/lib/test_signal.pro
1. IDL> @test_signal
Note: If executing this statement results in the error “% Error opening file.”, then the
“IDL_QS_Files/lib/” subfolder that contains this batch file is not included in IDL’s path. Please go back to
chapter 1 of this Quick Start tutorial and perform the steps delineated in the section entitled “Installing
the Tutorial Files” in order to rectify this problem.
Once this batch file has executed there will be 2 new variables called “x” (the
independent variable time) and “s” (the actual signal data) within the IDL session :
2. IDL> HELP, x, s
X FLOAT = Array[100]
S FLOAT = Array[100]
Both of these variables are vectors of 32-bit floating-point precision data that are
100 elements in length. To visualize this time-series signal simply make a call to the
iPlot procedure and maximize the display window :
The resulting IDL iPlot window will contain 4 view sub-windows. The line plot for the
independent variable “x” as the X component and the signal variable “s” as the Y
component will appear in the upper-left hand corner view window. The resulting
visualization should look similar to Fig. 6-2.
This signal has very sharp components that are analogous to noise. One way to
attenuate certain types of noise in a signal is by using the SMOOTH function within
IDL. The SMOOTH function filters an input array using a running-mean top hat
kernel of a user-specified width (boxcar average). The SMOOTH function moves the
kernel over the input array, element-by-element. At each step, the mean of the
elements of the input array that fall under the window of the kernel is calculated,
and this value is placed at the location of the centroid of the kernel at its current
array element location. For example, consider a simple vector with five elements :
When applying a SMOOTH function the output will be the average across the user-
specified kernel size. For instance, when using a kernel size of 3 the element in the
exact center of this vector would be replaced with the value (1.00 + 7.00 + 2.00) / 3
= 3.33. This is the output that results from smoothing the above vector using a
kernel with a size of 3 :
Apply the SMOOTH function to the test signal and visualize the results :
The smoothed signal will be displayed in the upper-right hand corner view window.
Smoothing a signal is this manner tends to distort the phase of the signal. Another
interesting way to visualize the effect is by viewing the residual signal that is left
after you remove the mean signal generated by the SMOOTH function from the
original signal :
The residual signal will contain information about the noise that the smoothing
process removed.
Another way to remove certain types of unwanted noise from a signal is by using the
MEDIAN function. The filtering process used by MEDIAN is similar to SMOOTH, but
the application of the kernel is quite different. In MEDIAN, the median value
(instead of the mean value) of the elements under the kernel is placed in the output
array at the current centroid location. For example, if a MEDIAN function is applied
to the same example vector :
Apply the MEDIAN function to the test signal and visualize the results :
The resulting IDL iPlot visualization window should look similar to Fig. 6-3.
12. Once finished viewing the modified signal line plots, close the IDL iPlot
window.
In addition, the CONVOL function in IDL also provides the ability to convolve a signal
with a user-defined kernel array. Convolution is a general process that can be used
for various types of smoothing, shifting, differentiation, edge detection, etc..
Digital filters can also be used to remove unwanted frequency components (e.g.
noise) from a sampled signal. Two broad classes of filters are Finite Impulse
Response (a.k.a. Moving Average) filters and Infinite Impulse Response (a.k.a.
Autoregressive Moving Average) filters.
Digital filters that have an impulse response that reaches zero in a finite number of
steps are called Finite Impulse Response (FIR) filters. An FIR filter is implemented
by convolving its impulse response with the data sequence it is filtering. IDL’s
DIGITAL_FILTER function computes the impulse response of an FIR filter based on
Kaiser’s window, which in turn is based on the Bessel function. DIGITAL_FILTER
constructs lowpass, highpass, bandpass, or bandstop filters.
The resulting IDL iPlot visualization window should look similar to Fig. 6-4.
20. Once finished viewing the modified signal line plots, close the IDL iPlot
window.
Correlation Analysis
The first step in the analysis of a time-series is the transformation to a stationary
series. A stationary series exhibits statistical properties that are unchanged as the
period of observation is moved forward or backward in time. Specifically, the mean
and variance of a stationary series remain fixed in time. The sample autocorrelation
function is commonly used to determine the stationarity of a time-series. The
autocorrelation of a time-series measures the dependence between observations as a
function of their time differences or lag. In other words, the autocorrelation of a
function shows how a function is related to itself as a function of a lag value. A plot
of the sample autocorrelation coefficients versus corresponding lags can be very
helpful in determining the stationarity of a time-series.
The resulting IDL iPlot visualization window should look similar to Fig. 6-5.
The autocorrelation measures the persistence of a wave within the whole duration of
a time-series. When the autocorrelation goes to zero, the process is becoming
random, implying there are no regularly occurring structures. An autocorrelation of
1 means the signal is perfectly correlated with itself. An autocorrelation of –1 means
the signal is perfectly anticorrelated with itself.
5. Once finished viewing the autocorrelation results, close the IDL iPlot window.
The resulting IDL iPlot visualization window should look similar to Fig. 6-6.
11. Once finished viewing the cross-correlation results, close the IDL iPlot
window.
The Discrete Fourier Transform (DFT) is the most widely used method for
determining the frequency spectra of digital signals (and is the only transform that
will be covered in this Quick Start). This is due in part to the development of an
efficient computer algorithm for computing DFTs known as the Fast Fourier
Transform (FFT). IDL implements the Fast Fourier Transform in its FFT function.
The DFT is essentially a way of estimating a Fourier transform at a finite number of
discrete points, which works well with a digital signal since it is also sampled at
discrete intervals.
The Fourier transform is a mathematical method that converts an input signal from
the physical (time or space) domain into the frequency (or Fourier) domain.
Functions in physical space are plotted as functions of time or space, whereas the
same function transformed to Fourier space is plotted versus its frequency
components. What the Fourier transform will help illustrate is that real signals can
often be comprised of multiple sinusoidal waves (with the appropriate amplitude and
phase) that when added together will re-create the real signal. In other words, the
FFT algorithm decomposes the input time-series into an alternative set of basis
functions, in this case sines and cosines.
The result of a FFT analysis is complex-valued coefficients, and spectra are derived
from these coefficients in order to visualize the transform. Spectra are essentially
the amplitude of the coefficients (or some product or power of the amplitudes) and
are usually plotted versus frequency. There are a number of different ways to
calculate spectra, but the primary forms are :
Although the real and imaginary parts contain some useful information, it is more
common to display the magnitude spectrum since it actually has physical
significance. Since there is a one-to-one correspondence between a complex
number and its magnitude (and phase for that matter), no information is lost in the
transformation from a complex spectrum to its magnitude. In IDL, the magnitude
can be easily computed using the absolute value (ABS) function :
The resulting IDL iPlot visualization window should look similar to Fig. 6-7.
Figure 6-7: Real and imaginary parts of DFT plus the magnitude spectrum
for the signal with sinusoidal component
10. Once finished viewing the magnitude spectrum, close the IDL iPlot window.
The resulting IDL iPlot visualization window should look similar to Fig. 6-8.
18. Once finished viewing the combined signal, close the IDL iPlot window.
Signals are usually sampled at regularly spaced intervals in time. For example, the
test signal dataset currently contained in the IDL variable “y” is a discrete
representation of three superposed sine and cosine waves at n=100 points. In this
case, the independent variable “x” that was used to create the test signal “y” is
sampled at regularly spaced intervals of time, which is assumed to be in units of
seconds. Consequently, the difference between any two neighboring elements in this
vector “x” is known as the sampling interval (δ) :
Since it is assumed that the time values are in units of seconds, it follows that the
sampling frequency for this test signal is ~16 Hz :
The resulting IDL iPlot visualization window should look similar to Fig. 6-9.
The original “sine” and “cosine” components (at 0.5 Hz and 2 Hz respectively) are
readily apparent in this magnitude spectrum, but there is also an aliased feature
located at 4.77 Hz ( Nyquist - (11.14-Nyquist) ). Furthermore, the shape of the
magnitude spikes vary from relatively narrow spikes to more diffuse features. For
instance, the peak at 2 Hz is more spread-out, and this is due to an effect known as
smearing or leakage. The leakage effect is a direct result of the definition of the
DFT and is not due to any inaccuracy in the FFT.
Note: Leakage can be reduced by increasing the length of the time sequence, or by choosing a sample
size that includes an integral number of cycles of the frequency component of interest.
31. Once finished viewing the magnitude spectrum, close the IDL iPlot window.
The phase spectrum of a Fourier transform can also be easily computed in IDL
using the arc-tangent (ATAN) function. By convention, the phase spectrum is usually
plotted versus frequency on a logarithmic scale :
The resulting IDL iPlot visualization window should look similar to Fig. 6-10.
37. Once finished viewing the phase spectrum, close the IDL iPlot window.
Finally, another way to visualize the same information is with the power spectrum,
which is the square of the magnitude of the complex spectrum :
41. Once finished viewing the power spectrum, close the IDL iPlot window.
Windowing
The leakage effect mentioned previously is a direct consequence of the definition of
the Discrete Fourier Transform, and of the fact that a finite time sample of a signal
often does not include an integral number of some of the frequency components in
the signal. The effect of this leakage can be reduced by increasing the length of the
time sequence or by employing a windowing algorithm. IDL’s HANNING function
computes two windows that are widely used in signal processing :
Hanning Window
Hamming Window
The resulting IDL iPlot visualization window should look similar to Fig. 6-12.
The power spectrum of the Hanning windowed signal shows some mitigation of the
leakage effect.
5. Once finished viewing the power spectrums, close the IDL iPlot window.
The WV_CWT function within IDL can be utilized to calculate the continuous wavelet
transform for a signal. Use the WV_CWT function to compute the transform for the
signal currently stored in the variable “y” using a Gaussian wavelet function :
Next, create the power spectrum for this continuous wavelet transform :
Finally, display the continuous wavelet power spectrum within the iImage utility :
The resulting IDL iImage visualization window should look similar to Fig. 6-13.
The display of the wavelet power spectrum clearly illustrates the sinusoidal
components contained in the input signal.
10. Once finished viewing the continuous wavelet power spectrum, close the IDL
iImage window.
11. Before moving on to the next chapter, it is a good idea to reset the IDL
session. This can be accomplished by executing the statement :
IDL> .reset_session
In the following exercise, the image from the example data file “meteorite.bmp” will
be input into IDL. This example data file is located in the “data” subfolder of the
Quick Start directory :
• Windows: C:\RSI\IDL##\IDL_QS_Files\data\meteorite.bmp
• UNIX et al.: /usr/local/rsi/idl_#.#/IDL_QS_Files/data/meteorite.bmp
• Mac OS X: /Applications/rsi/idl_#.#/IDL_QS_Files/data/meteorite.bmp
The file is in Windows bitmap format and contains an image of a thin section taken
through the Shergotty meteorite that is believed to represent a sample of the surface
of Mars. Input the image data into the current IDL session by utilizing the Import
Image macro built into the IDL Development Environment :
1. Start by selecting “Macros > Import Image” from the main IDL Development
Environment window. A dialog entitled Select Image File will appear.
2. Navigate to the “data” subfolder of the Quick Start directory and select the
“meteorite.bmp” file. Information on the image and a small preview will be
displayed in the bottom of the Select Image File dialog [Fig. 7-1].
3. Press the “Open” button to read the image data into IDL and dismiss the
Import Image wizard.
Once the Import Image macro is finished running the user will be returned to the
main IDLDE window where a new variable named “meteorite_image” is now present
within the current IDL session. The HELP procedure can be used to obtain
information on this variable :
The output from the HELP procedure shows that the “meteorite_image” variable is
actually a structure containing multiple pieces of data and information read in from
the BMP image file. To obtain information on the contents of this structure variable
the HELP procedure must be executed with the STRUCTURE keyword set :
The actual image data from the BMP file is stored in the IMAGE tag of the structure
variable, which contains a 2-dimensional array that has 514 columns and 343 rows
with an 8-bit (BYTE) data type. The R, G, and B tags within the structure variable
are provided to store the color table vectors that can be stored within 8-bit BMP files,
which in this case are not necessary since the image is in simple grayscale mode.
Furthermore, the QUERY tag stores yet another sub-structure that contains other
useful information on the BMP image file.
The QUERY field contains some useful information on the BMP image file. In order to
access the actual image data stored within the “meteorite_image” structure in a
manner that does not require a lot of typing, extract the IMAGE field of the structure
and assign it to a new variable named “image” :
Once this is accomplished a new variable is created at the main IDL level that is
simply called “image” :
Now that the image data has been extracted into a simple variable it can be easily
visualized by loading it into the iImage utility :
The resulting IDL iImage visualization window should look similar to Fig. 7-2.
On the right-hand side of the IDL iImage window the “Min:” and “Max:” boxes show
that the pixels in the image range throughout the full 8-bit range (0 255).
However, the histogram plot window illustrates that most of the pixels within the
image have brightness values in the lower half of the data range. The histogram plot
is essentially portraying the overall dark gray to black appearance of the image.
10. Within the “Max:” field box, type a pixel data value of 110 and press the Enter
key on the keyboard. This will saturate all pixels in the image with a value of
110 or higher to white, while stretching the pixels with values 0 109
throughout the full range of the grayscale display.
The resulting IDL iImage visualization window should look similar to Fig. 7-3.
This manipulation of the histogram stretch bars only affects the display of the image
and does not change the actual pixel values for the image dataset. Notice that the
“Pixel Value:” field within the Image panel now displays a number in parentheses
next to the actual pixel data value. This number in parentheses is the output
grayscale intensity for the current pixel according to the stretch that is being applied.
11. Change the “Max:” field back to “255” by either typing in the text box or
clicking on the green stretch bar and dragging it back up to the top of the
histogram display window.
There are a number of analysis tools found within the Operations menu of the iImage
utility. The operations that are built into the iTools system represent some of the
most common image processing tasks.
12. While the image object is selected within the IDL iImage window, select
“Operations > Statistics…” from the menu system.
A separate dialog will appear that displays some statistical information on the current
image dataset [Fig. 7-4]. Notice that the average (mean) pixel value for this image
is 47.7387, which explains the relatively dark appearance of the original image.
13. Once finished viewing the image statistics, close the Display statistics for the
selected item dialog.
One of the operations built into the iImage utility is the Unsharp Masking
technique, which applies a sharpening filter to the image. Digital Unsharp Masking
is a digital image processing technique that increases the contrast where subtle
details are set against a diffuse background. This operation suppresses features
which are smooth (those with structures on large scales) in favor of sharp features
(those with structure on small scale), resulting in a net enhancement of the contrast
of fine structure in the image.
14. From the IDL iImage window menu system select “Operations > Filter >
Unsharp Mask”.
15. Within the Unsharp Mask dialog that pops up, leave all parameters set to their
default values and simply press “OK”.
Notice that the fine detail within the image is enhanced by applying the Unsharp
Mask operation.
The iImage utility also has a built-in tool for convolving an image array with a kernel.
Convolution is a simple matrix algebra operation that can be used for various types
of smoothing, shifting, differentiation, edge detection, etc..
16. Select “Operations > Filter > Convolution” from the iImage menu system. A
separate dialog entitled Convolution Kernel Editor will appear [Fig. 7-5].
The Convolution Kernel Editor window allows the user to select from a list of pre-
defined kernels, or define their own user-defined kernel. The convolution of these
different kernels will have a wide variety of effects on the resulting image display.
The Laplacian filter can be applied by convolving a Laplacian kernel with the image.
A Laplacian filter is an edge enhancement filter that operates without regard to edge
direction. Laplacian filtering emphasizes maximum values within the image by using
a kernel with a high central value typically surrounded by negative weights in the up
down and left-right directions and zero values at the kernel corners. The Laplacian
kernel convolution is a form of high pass filter, which removes the low frequency
components of an image while retaining the high frequency (local variations). It can
be used to enhance edges between different regions as well as to sharpen an
image.
17. Using the droplist next to the “Filter” parameter in the upper left hand corner
of the Convolution Kernel Editor dialog, select the “Laplacian” kernel.
The application of the Laplacian filter will enhance the edges between different
regions (in this case mineral grains) within the image. The resulting IDL iImage
visualization window should look similar to Fig. 7-6.
IDL also has a number of morphological image operators built into its library of
routines. Mathematical morphology is a method of processing digital images on the
basis of shape. Some of these morphological algorithms have been added to the
operations within the iTools system. For example, the dilate operator, which is
commonly known as the "fill", "expand", or "grow” operator, can be used to further
enhance the boundaries between mineral grains in the current image.
21. Select “Operations > Morph > Dilate” from the iImage menu system. A
separate dialog entitled Dilate will appear [Fig. 7-7]. The parameters
The resulting IDL iImage visualization window should look similar to Fig. 7-8.
24. Once finished viewing the processed image, close the IDL iImage window.
In addition to sharpening, high pass filtering, and edge enhancement techniques, IDL
also offers operations to perform image smoothing, low pass filtering, and noise
removal. Re-launch the iImage utility with the original image so these techniques
can be investigated :
The median operation replaces each pixel with the median of the two-dimensional
neighborhood of the specified width. In an ordered set of values, the median is a
value with an equal number of values above and below it. Median filtering is
effective in removing salt and pepper noise (isolated high or low values). The
resulting image will have a less grainy appearance than the original.
26. From the iImage menu system, select “Operations > Filter > Median”.
27. Within the Median dialog window, leave all of the default settings and press
“OK”.
The smooth operation will compute the boxcar average of a specified width for the
image. Smoothing is similar to the median filter except the pixels are replaced with
the average (mean) value across the neighborhood. This tends to have the effect of
blurring the edges within the image and making them more diffuse.
Finally, the Convolution tool can be used once again to apply a low pass filter to the
image. The Gaussian kernel provides a form of low pass filtering that preserves the
low frequency components of an image.
30. Select “Operations > Filter > Convolution” from the iImage menu system.
31. Within the Convolution Kernel Editor dialog, change the “Filter” selection
droplist to “Gaussian” [Fig. 7-9].
32. Edit the number of columns and rows fields so the kernel has a size of 5 x 5
[Fig. 7-9].
33. Press the “OK” button to apply the Gaussian filter and dismiss the dialog.
Figure 7-10: Image display after noise removal, smoothing, and low pass
filtering
34. Once finished viewing the processed image, close the IDL iImage window.
For example, in order to threshold the Shergotty meteorite image and identify the
pixels that have a value greater than 70 (byte) simply execute the following
statement :
This expression creates a new variable named “mask” that is a 2-dimensional array
of the same size as the original image. This new “mask” variable contains a binary
image where each pixel has a value of either one (original image pixel value was
greater than 70) or zero (original image pixel value was equal to or less than 70). At
this point, the user may wish to view this binary threshold image by loading it into
the iImage utility :
The resulting image display within the IDL iImage window should appear completely
black. This is due to the fact that all of the pixels within the “mask” binary image
have a value of 0 or 1, which are very difficult to discern (and very dark) within a 0
255 grayscale display. Consequently, the BYTSCL function should be utilized
when displaying binary images so the pixels with a value of 1 are actually mapped to
255 (white). The BYTSCL function scales all values of an array into a specified range
(0 255 by default) :
The resulting IDL iImage visualization window should look similar to Fig. 7-11.
5. Once finished viewing the binary threshold image, close the IDL iImage
window.
Binary threshold images can also be used to mask-out the pixels in an image that
do not qualify based on the given expression. For example, in order to display only
those pixels from the original image that have a value greater than 70 simply
execute the following statements :
The resulting IDL iImage visualization window should look similar to Fig. 7-12.
8. Once finished viewing the masked image, close the IDL iImage window.
The user can also provide both upper and lower bounds when creating threshold
images by using the Boolean operators built into IDL (AND, NOT, OR, and XOR). For
example, create a threshold image that identifies those pixels which have a data
value between 50 and 70 :
The resulting IDL iImage visualization window should look similar to Fig. 7-13.
11. Once finished viewing the threshold image, close the IDL iImage window.
Clipping is similar to thresholding because pixels with data values above or below a
specified level are all set to the same value. However, when clipping an image the
pixels that do not satisfy the expression are set to the selected level and the
resulting image is not binary in nature. Clipping can be used to enhance features
within an image.
In IDL, clipping is performed with the minimum (<) and maximum (>) operators. In
order to clip an image the user must design an expression that contains an image
array, the appropriate operator, and the clipping level. For example, to clip the
meteorite thin section image so that all pixels with a value greater than or equal to
50 are set to a value of 50 simply execute the following statements :
The resulting IDL iImage visualization window should look similar to Fig. 7-14.
14. Once finished viewing the clipped image, close the IDL iImage window.
The resulting IDL iImage visualization window(s) should look similar to Fig. 7-15.
19. Once finished viewing the stretched image, close the IDL iImage window(s).
In addition to simple linear stretching techniques, IDL also has routines that allow
the user to stretch the image using other histogram manipulations. For example, the
HIST_EQUAL function can be used to apply a histogram equalization stretch to the
image data. Histogram equalization employs a monotonic, non-linear mapping which
re-assigns the intensity values of pixels in the input image such that the output
image contains a uniform distribution of intensities (i.e. a flat histogram). Execute
the following statements in order to derive and display the histogram-equalized
version of the meteorite thin section image :
Notice that the resulting image has improved contrast and the histogram has a very
even distribution throughout the 0 255 range. The resulting IDL iImage
visualization window should look similar to Fig. 7-16.
22. Once finished viewing the histogram-equalized image, close the IDL iImage
window.
The resulting IDL iImage visualization window should look similar to Fig. 7-17.
25. Once finished viewing the adaptive histogram-equalized image, close the IDL
iImage window.
Start by thresholding the Shergotty meteorite image in order to identify the dark
mineral grains with a pixel value less than or equal to 20 :
Next, create a structuring element array with a square shape that will help extract
objects with sharp rectangular edges :
The MORPH_CLOSE function can be used with this structuring element to apply the
closing operator to the binary threshold image. The closing operator has the effect
of clumping the threshold image, thereby filling in holes within and connecting gaps
between neighboring regions. In addition, the MORPH_OPEN function can be
subsequently used to apply the opening operator, which will have a sieving effect on
the image that helps to remove small isolated regions. Apply these morphological
operations and visualize the results in comparison to the original image :
The resulting IDL iImage visualization window should look similar to Fig. 7-18.
The resulting IDL iImage visualization window should look similar to Fig. 7-19.
26. Once finished viewing the segmentation image, close the IDL iImage window.
In the frequency or Fourier domain, the value and location are represented by
sinusoidal relationships that depend upon the frequency of a pixel occurring within
an image. In this domain, pixel location is represented by its X and Y frequencies
and its value is represented by an amplitude. Images can be transformed into the
frequency domain to determine which pixels contain the most important information
and whether repeating patterns occur.
In IDL, the FFT routine can be utilized to perform a Fast Fourier Transformation
and convert an image from the spatial domain into the frequency domain. In the
following exercise, the image data from the example data file “hamburg.jp2” will be
input into the iImage utility and subsequently transformed into the Fourier domain.
This example data file is located in the “data” subfolder of the Quick Start directory :
• Windows: C:\RSI\IDL##\IDL_QS_Files\data\hamburg.jp2
• UNIX et al.: /usr/local/rsi/idl_#.#/IDL_QS_Files/data/hamburg.jp2
• Mac OS X: /Applications/rsi/idl_#.#/IDL_QS_Files/data/hamburg.jp2
The file “hamburg.jp2” is in JPEG2000 format and contains a satellite image of the
loading docks at the port in Hamburg, Germany. Start by loading this image into a
new iImage utility :
1. IDL> iImage
2. From the iImage menu system select “File > Open…”.
3. Select the “hamburg.jp2” file and hit “Open”.
The resulting image display should look similar to Fig. 7-20. Notice the linear and
rectangular patterns that are prevalent in this image in both diagonal directions.
Once the image has been loaded into the iImage utility, it can be exported to an IDL
variable for processing at the IDL> command prompt. Use the following steps to
create a variable for this image at the main IDL level :
A new variable named “hamburg” now exists at the main IDL level :
In order to work with this image in the frequency domain it is beneficial to extract
the individual color channel images. This can be accomplished using IDL’s standard
array subscripting syntax in conjunction with the REFORM function, which is used to
remove the first dimension (that has a size of one) and return a simple two-
dimensional array :
Note: Remember that the up-arrow and down-arrow keys on the keyboard can be used to perform
command recall within IDL, which may be beneficial during these exercises.
Once this is accomplished, the FFT routine can be used to transform the image
planes into the frequency domain :
The Fast Fourier Transform decomposes an image into sines and cosines of varying
amplitudes and phases. The values of the resulting transform represent the
amplitudes of particular horizontal and vertical frequencies. The data type of the
array returned by the FFT function is complex, which contains real and imaginary
parts :
The amplitude is the absolute value of the FFT, while the phase is the angle of the
complex number, computed using the arctangent. In most cases, the imaginary part
will look the same as the real part.
The image information in the frequency domain shows how often patterns are
repeated within an image. Within the Fourier domain, low frequencies represent
gradual variations in an image, while high frequencies correspond to abrupt
variations in the image. The lowest frequencies usually contain most of the
information, which is shown by the large peak in the center of the result. If the
image does not contain any background noise, the rest of the data frequencies are
very close to zero.
The results of the FFT function are often shifted to move the origin of the X and Y
frequencies to the center of the display. Furthermore, the range of values from the
peak to the high frequency noise is usually extreme. Consequently, a logarithmic
scale is often utilized in order to visualize the image in the frequency domain. Since
the logarithmic scale only applies to positive values, the power spectrum should be
computed since it is the absolute value squared of the Fourier transform.
Visualize the power spectrum of the Fourier domain image for the green channel by
executing the following statements :
The resulting IDL iImage visualization window should look similar to Fig. 7-22.
Notice the orientation of spatial patterns within the power spectrum image in both of
the diagonal directions (just like the original image).
23. Once finished viewing the power spectrum image, close the IDL iImage
window.
It may also be beneficial to visualize the power spectrum as a surface. Use the
REBIN function to sub-sample the power spectrum in order to suppress some of the
noise and set the shading for the surface to Gouraud :
The resulting IDL iSurface visualization window should look similar to Fig. 7-23.
25. Once finished viewing the power spectrum surface, close the IDL iSurface
window.
Low frequencies within the image tend to contain the most information because they
determine the overall shape or patter in the image. High frequencies provide detail
in the image, but they are often contaminated by the spurious effects of noise.
Consequently, masks can be easily applied to an image within the frequency domain
in order to remove noise.
Create a mask for the low spatial frequency components based on the highest values
within the power spectrum for the green channel image :
Note: The threshold value of –2.5 was arbitrarily selected based on the surface visualization above.
Figure 7-24: Mask of the low spatial frequency components (white) within
the power spectrum for the green color channel
Notice that the low frequency components are found predominantly in the center of
the power spectrum.
28. Once finished viewing the mask image, close the IDL iImage window.
In order to remove the high spatial frequency noise from the image, this mask must
be applied to the Fourier transform data and then the inverse FFT must be
computed. Applying the low spatial frequency mask allows these components to be
converted back to the spatial domain during the inverse transform, while the high
spatial frequency components are masked out.
First, the mask image must be shifted back to the original location of the Fourier
transform :
Once this is accomplished, the mask can be applied to the FFT results for the 3 color
channels :
The inverse FFT can be used in conjunction with the REAL_PART function in order to
convert the images back into the spatial domain :
The result can be visualized by loading the individual color channel images into the
iImage utility [Fig. 7-25] :
Figure 7-25: Result of the inverse FFT after the high spatial frequency
components have been masked out (low pass filter)
37. Once finished viewing the inverse FFT image, close the IDL iImage window.
The high spatial frequency components of an image can also be enhanced using
masking techniques in the frequency domain. A circular-cut (high pass) filter can
be created by utilizing the DIST function in IDL and the appropriate threshold value :
Visualize this mask by shifting it into the appropriate location and loading the result
into the iImage utility [Fig. 7-26] :
Figure 7-26: Circular-Cut filter for the high spatial frequency components
(white) within the image
Notice that the high frequency components are found around the outer edges of the
transform.
40. Once finished viewing the mask image, close the IDL iImage window.
Use the same methodology as before to apply the high pass filter, compute the
inverse FFT, and display the result :
The resulting IDL iImage visualization window should look similar to Fig. 7-27.
Figure 7-27: Result of the inverse FFT after the low spatial frequency
components have been masked out (high pass filter)
48. Once finished viewing the inverse FFT image, close the IDL iImage window.
49. Before moving on to the next chapter, it is a good idea to reset the IDL
session. This can be accomplished by executing the statement :
IDL> .reset_session
Introduction to Mapping
In some cases the data that is being analyzed may be related to a location or area
on the surface of the Earth, and it is usually beneficial to visualize this data within a
map projection. Map projections are attempts to portray the surface of the earth
or a portion of the earth on a flat surface (in this case the computer monitor screen).
Every flat map misrepresents the surface of the Earth in some way. Consequently,
no 2-D map can rival a 3-D globe in truly representing the surface of the entire
Earth. Some distortions of conformality, distance, direction, scale, and area always
result from this process. However, a map or parts of a map can show one or more
(but never all) of the following :
• True Directions
• True Distances
• True Areas
• True Shapes
IDL has several built-in routines that deal with creating, manipulating, and displaying
data within map projections. In addition, the installation of the IDL software
package includes three databases that can be useful when mapping at a small scale
(i.e. over a large regional area) :
Note: The “High Resolution Maps” is an optional item that is not installed by default. If this item was not
installed the user can go back to the software installer and modify the contents of the distribution in order
to add this database.
The iTools system within the IDL software package contains a pre-built utility for
working with data in a map projection called iMap. The iMap utility displays image
and contour data that are georeferenced to a particular map projection. The iMap
tool gives the user great flexibility in manipulating and visualizing these datasets.
Images and contour data can be warped from geographic (latitude / longitude)
Launch the iMap utility by executing the iMap procedure at the IDL> command
prompt :
1. IDL> iMap
Start by inserting some of the vector data from the ESRI Shapefile database included
with the IDL software installation :
2. From the IDL iMap window menu system select “Insert > Map > Continents”.
Since the iMap tool is currently in its initial state with no active map projection
defined, the vector data is displayed in the standard geographic (lat/lon) coordinate
system.
Next, insert the low-resolution countries, along with the United States and Canadian
province boundaries, and the longitude-latitude grid :
3. Select “Insert > Map > Countries (low res)” from the iMap menu system.
4. Select “Insert > Map > United States” from the iMap menu system.
5. Select “Insert > Map > Canadian Provinces” from the iMap menu system.
6. Select “Insert > Map > Grid” from the iMap menu system.
The resulting IDL iMap visualization window should look similar to Fig. 8-1.
Currently the data is displayed in the geographic lat/lon coordinate system and has
not been warped into a specific map projection. The data can be viewed in any of
the supported map projections by editing the current map projection within the iMap
utility. Use the following steps to change the map projection to Mercator with the
WGS-84 datum :
7. Press the “Edit Projection…” button on the Map panel in the bottom right-hand
corner of the IDL iMap window. The Map Projection dialog will appear [Fig. 8-
2].
8. Within the Map Projection dialog change the “Projection” droplist to
“Mercator” [Fig. 8-2].
9. Change the “Ellipsoid (datum)” droplist to “WGS 84” [Fig. 8-2].
10. Press the “OK” button to apply the changes and dismiss the Map Projection
dialog.
The cursor will change to an hourglass while the transformation is processing. Once
the conversion is complete, it may be beneficial to change some of the properties
associated with the map objects so they are easier to identify within the
visualization.
11. From the IDL iMap window menu system, select “Window > Visualization
Browser…”. A dialog entitled “IDL iMap: Visualization Browser” will appear
[Fig. 8-3].
12. Click on the “Map Grid” object so it is selected within the left visualization
panel [Fig. 8-3].
13. Click on the show right panel button to display the property sheets for the
selected object [Fig. 8-3].
14. Change the “Line style” property to dashed and the “Color” property to blue
for the “Map Grid” object [Fig. 8-3].
15. Next, select the “Canadian Provinces” object, change the “Color” to green, set
“Fill background” to True, change the “Fill color” to orange, and set the
“Transparency” to “0”.
16. Select the “United States” object, change the “Color” to red, set “Fill
background” to True, change the “Fill color” to yellow, and set the
“Transparency” to “0”.
17. Close the Visualization Browser window.
The resulting IDL iMap visualization window should look similar to Fig. 8-4.
• Windows: C:\RSI\IDL##\IDL_QS_Files\data\colorado.jpg
• UNIX et al.: /usr/local/rsi/idl_#.#/IDL_QS_Files/data/colorado.jpg
• Mac OS X: /Applications/rsi/idl_#.#/IDL_QS_Files/data/colorado.jpg
The file is in JPEG format and contains a hill shade image of a digital elevation model
for a portion of the state of Colorado. Start by inputting this image into a new iMap
utility window :
1. IDL> iMap
2. Select “File > Open…” from the iMap menu system.
3. Select the file “colorado.jpg” and press “Open”.
The IDL Map Register Image dialog will be displayed, which walks the user through
the steps of specifying the geolocation for the image dataset.
Once the minimum and maximum values have been entered the appropriate pixel
size is automatically computed based on the size of the image (approximately
0.00333 degrees).
6. Press the “Finish” button to complete the geolocation definition and return to
the IDL iMap window.
The standard Image panel will automatically be placed along the right-hand side
within the current tool window since the data being displayed is an image [Fig. 8-6].
This is the same Image panel that is present within the iImage utility.
7. Maximize the IDL iMap window and scale the image so it fits within the
current view space.
The “Pixel Location:” and “Pixel Value:” fields within the Image panel will show the
mouse cursor location within the image and the pixel values in each of the 3 color
channels, while the geographic location is displayed in the lower-right hand corner of
the IDL iMap window [Fig. 8-6].
8. Using the mouse, click on the Map panel tab to switch back to the original tool
configuration.
Notice that the longitude and latitude locations are also reported in the Map panel as
the mouse cursor is moved over the image display.
Now that the image has been imported into the iMap utility and the geolocation has
been defined, a new map projection for the tool can be defined. In this case, it will
be beneficial to visualize the current image within the UTM map projection. The area
within the state of Colorado that this image covers is located within UTM zone #13
(North). Use the following steps to change the current map projection to UTM :
The mouse cursor will change to a hourglass while the map projection conversion of
the image data is processing. Once the conversion is complete the map projection
for the iMap tool will now be UTM. The resulting IDL iMap visualization window
should look similar to Fig. 8-8.
Notice that the image has been warped to conform to the specifications of the UTM
map projection. Also notice that the geographic location that is reported while the
mouse cursor is moved over the image is now includes Easting and Northing in units
of meters.
13. Once finished viewing the map visualization, close the IDL iMap window.
In the following exercise, the DEM data from the example data file
“New_Zealand_DEM.tif” will be input into IDL and displayed using iContour. This
example data file is located in the “data” subfolder of the Quick Start directory :
• Windows:
C:\RSI\IDL##\IDL_QS_Files\data\New_Zealand_DEM.tif
• UNIX et al.:
/usr/local/rsi/idl_#.#/IDL_QS_Files/data/New_Zealand_DEM.tif
• Mac OS X:
/Applications/rsi/idl_#.#/IDL_QS_Files/data/New_Zealand_DEM.tif
The file is in TIFF format and contains elevation values for both the north and south
islands of New Zealand. The elevation data is in units of meters and ranges from
sea-level (0 m) up to the highest elevation (3173 m). Start by inputting this data
into a new iContour utility :
1. IDL> iContour
2. Select “File > Open…” from the iContour menu, select the
“New_Zealand_DEM.tif” file, and press “Open”.
A contour object with the default properties will be inserted into the IDL iContour
window. Since the iContour utility automatically creates a certain number of
contours at evenly spaced intervals from the minimum data value to the maximum,
it is difficult to see the outline of the two islands. In this case, it is beneficial to
change the minimum contour value from the default 0.0 (sea level) to an elevation
slightly above the ocean in order to see the edge of the land mass. In addition, the
data space scaling is anisotropic by default, which leads to a difference between the
length of two axes.
The outline of both the north and south islands of New Zealand should now be
readily visible [Fig. 8-10].
Figure 8-10: Contour of the New Zealand digital elevation model data
13. Once finished viewing the contour visualization, close the IDL iContour
window.
14. Confirm that the new variable named “nz” exists at the main IDL level :
IDL> HELP, nz
NZ INT = Array[760, 819]
Next, create variables for the input parameters to the MAP_PROJ_INIT function that
define the geographic location of the current dataset. The MAP_PROJ_INIT function
will be used to define the map projection structure for a Stereographic map
projection that is centered over the country of New Zealand.
Use the MAP_PROJ_INIT function to define a Stereographic map projection with the
appropriate parameters :
Next, define the range for the current dataset and warp into the Stereographic map
projection using the MAP_PROJ_IMAGE function :
Finally, create a vector of elevation values for the contour levels and load the two
datasets into a new iMap utility :
Once again, the scaling of the axes are anisotropic by default, so change the scaling
and insert a legend into the current visualization :
24. Select “Window > Visualization Browser…” from the iContour menu system.
25. Select the Data Space object and change the “Isotropic scaling” field to
“Isotropic”.
26. While the Data Space object is selected, go back to the iContour menu
system and select “Insert > New Legend”.
27. Close the Visualization Browser window.
The resulting IDL iMap visualization window should look similar to Fig. 8-12.
28. Once finished viewing the contour maps, close the IDL iMap window.
29. Before moving on to the next chapter, it is a good idea to reset the IDL
session. This can be accomplished by executing the statement :
IDL> .reset_session
All of the graphical visualizations that have been created thus far have been in one of
the pre-built iTools utilities (iPlot, iContour, iSurface, iImage, iVolume, iMap). The
three graphical systems are listed above in order of increasing age; the iTools were
introduced in IDL version 6.0 (2003), the Object Graphics were introduced in version
5.0 (1997), and the Direct Graphics have been in IDL since the beginning. There is
actually an inherent relationship between the iTools and the Object Graphics because
the iTools system is merely a set of interactive (point-and-click) utilities with a
graphical user interface that are built on top of the underlying Object Graphics
components. In contrast, the Direct Graphics are a completely separate graphical
system that require a very unique syntax. Each graphical system has distinct
advantages in comparison to the others, and this chapter presents an introduction to
the Direct and Object Graphics systems.
The Direct Graphics rely on the concept of a current graphics device. The routines
in the IDL language that create Direct Graphics will send the graphical output directly
to the current graphics device. The relevant features of the Direct Graphics system
are :
This two-dimensional array can be visualized using the Direct Graphics version of the
surface graphic by making a call to the SURFACE procedure :
One of the primary benefits of the Direct Graphics system is its ability to rapidly
render graphics to the current device, especially when the dataset is very large.
However, once the visualization is drawn to the display device the user no longer has
any control over the graphic.
4. For example, position the cursor over the IDL 0 window and click-and-drag
using the mouse. Notice that the Direct Graphics display window does not
provide the ability to interactively manipulate (rotate, translate, zoom, etc.)
the current visualization.
5. Click on the maximize button in the upper-right hand corner of the IDL 0
window, or simply click on the edge of the window and drag.
Notice that the surface visualization does not automatically resize with the change in
window size. Moreover, if the user decreases the size of the display window to an
area smaller than the original graphic, then re-exposes the area where the graphic
first appeared the visualization will not automatically repair itself.
6. Click on the edge of the IDL 0 window and make it small enough to hide a
portion of the surface graphic. Then, drag the edge of the window back out
to show the full display area for the original visualization. Notice that the
graphic has been erased.
7. Close the current IDL 0 graphics window.
If the user wants to re-draw the graphic, or modify some property of the
visualization, the commands that are used to create the graphic must be re-issued.
In addition, aspects of the current graphics device (e.g. the current color lookup
table) might need to be modified. For example, in order to change the color of the
wire-mesh surface graphic to red, decomposed color must be disabled using the
DEVICE procedure, the RGB triplet for the color red must be loaded into a color table
index using the TVLCT procedure, and the call to the SURFACE procedure must be
re-issued :
The surface graphic and axes within the Direct Graphics visualization window should
now be red.
11. Once finished viewing the Direct Graphics surface visualization, close the IDL
0 display window.
Now create the same surface visualization within the Object Graphics system. This
can be accomplished by making a call to the OBJ_SURFACE procedure :
Note: The OBJ_SURFACE routine is a custom program that is included with the distribution materials for
this IDL Quick Start tutorial. This program is basically a wrapper on top of the appropriate Object
Graphics components. If executing this statement results in the error “% Error opening file.”, then
the “IDL_QS_Files/lib/” subfolder that contains this batch file is not included in IDL’s path. Please go back
to chapter 1 of this Quick Start tutorial and perform the steps delineated in the section entitled “Installing
the Tutorial Files” in order to rectify this problem.
The surface graphic visualization will appear within a window that has a bit more
functionality than the default Direct Graphics display window [Fig. 9-2]. A series of
bitmap buttons across the toolbar expose manipulation functionality (rotate, zoom,
By default, this Object Graphics display utility is setup in Rotate manipulation mode :
13. Position the cursor within the window and click-and-drag with the mouse in
order to rotate the graphic.
One of the primary advantages of the inherent 3-D rendering of the Object Graphics
system is the ability to expose robust interactive manipulation capabilities to the
user. In addition to the Rotate manipulation, experiment with the Zoom and Pan
capabilities :
14. Click on the Zoom button to enter zoom manipulation mode, then click-
and-drag with the mouse cursor within the display window.
15. Click on the Pan button to enter translate manipulation mode, then click-
and-drag with the mouse cursor within the display window.
18. Once finished viewing the surface visualization, close the OBJ_SURFACE
window.
The evolution of IDL’s graphical systems from Direct Graphics Object Graphics
iTools has led to the development of a robust environment for data visualization that
has the convenience of point-and-click user interaction along with the power and
control of a programming language. At this point, users might be asking
themselves, “Why would I ever want to use the Direct or Object Graphics systems
directly? Why wouldn’t I always just use the iTools graphical system?”. The
following table clearly delineates the primary advantages and disadvantages of the 3
graphical systems :
The output from the execution of this statement should be similar to the following :
Since the example above was generated on a Windows computer the default current
graphics device is “WIN”, which is the computer monitor screen. If this command
was executed on a UNIX, Linux, or Mac OS X computer the current graphics device
should be “X”, which is short for X-windows.
The SET_PLOT procedure must be used to select the graphic device to which IDL
directs its output. For example, change the current Direct Graphics output device to
the PostScript device and obtain information :
The output from the execution of this statement should be similar to the following :
At this point, if the user were to execute a routine from the IDL library that creates
Direct Graphics visualizations the graphical output would actually be directed to this
invisible PostScript device and would not appear on the computer monitor screen.
4. In order to create Direct Graphics visualizations and see them on the display,
change the current graphics device back to its original setting :
The !D system variable within the IDL language also stores useful information on the
current Direct Graphics output device in a structure. The user can view these
settings by using the HELP procedure with the STRUCTURE keyword set :
The output from the execution of this statement should be similar to the following :
However, the !D system variable is read-only and cannot be modified directly by the
user. In order to control the settings for the current graphics device (and obtain
other useful information) the DEVICE procedure must be used. The DEVICE
procedure controls the graphic device-specific functions for the device currently
selected by SET_PLOT. An attempt has been made to isolate all device-specific
functionality in this procedure.
Once this is accomplished, executing the command “HELP, /DEVICE” will show that
the current Direct Graphics device is using decomposed (24-bit) color :
The primary advantages of the Direct Graphics system is efficient handling of large
datasets and very rapid rendering. The following exercise illustrates one of these
benefits by executing a small GUI program that utilizes Direct Graphics (and IDL’s
widget toolkit). This program displays an image of a digital elevation model and
allows the user to click on the image and dynamically display X- and Y- line profiles
of the DEM data in a very rapid fashion. The data that is used in this exercise is
stored in the file named “DEM.tif” located in the “data” subfolder of the Quick Start
directory :
• Windows: C:\RSI\IDL##\IDL_QS_Files\data\DEM.tif
• UNIX et al.: /usr/local/rsi/idl_#.#/IDL_QS_Files/data/DEM.tif
• Mac OS X: /Applications/rsi/idl_#.#/IDL_QS_Files/data/DEM.tif
Start by launching the custom program that is built on top of the Direct Graphics
system :
8. IDL> PROFILE_VIEW
Note: The PROFILE_VIEW routine is a custom program that is included with the distribution materials for
this IDL Quick Start tutorial. This program is basically a wrapper on top of the appropriate Direct Graphics
components. If executing this statement results in the error “% Error opening file.”, then the
“IDL_QS_Files/lib/” subfolder that contains this batch file is not included in IDL’s path. Please go back to
chapter 1 of this Quick Start tutorial and perform the steps delineated in the section entitled “Installing
the Tutorial Files” in order to rectify this problem.
A standard native file selection dialog will appear entitled “Select “DEM.tif” file to
open”.
9. Select the file named “DEM.tif” and press the “Open” button.
A new Direct Graphics display window entitled “Profile Viewer” will appear with an
image display of the DEM data and two blank plot windows. This program window
allows the user to click-and-drag with the left mouse button on top of the image in
10. Once finished viewing the line profiles, close the Profile Viewer window.
The next exercise illustrates another aspect of the Direct Graphics system’s rapid
rendering by displaying a very large image in a window that allows the user to
rapidly move a zoom window around on top of the picture using the mouse. The
image that will be used is stored in the file “St_Louis.jpg” located in the “data”
subfolder of the Quick Start directory :
• Windows: C:\RSI\IDL##\IDL_QS_Files\data\St_Louis.jpg
• UNIX et al.: /usr/local/rsi/idl_#.#/IDL_QS_Files/data/St_Louis.jpg
• Mac OS X: /Applications/rsi/idl_#.#/IDL_QS_Files/data/St_Louis.jpg
The file is in JPEG format and contains a 2000 x 2000 satellite image of downtown
St. Louis, Missouri. Both the Edward Jones Dome and Busch Stadium are readily
visible in this image. Start by launching a custom program that is built on top of the
Direct Graphics system :
Note: The IMAGE_FULLRES_ZOOM routine is a custom program that is included with the distribution
materials for this IDL Quick Start tutorial. This program is basically a wrapper on top of the appropriate
Direct Graphics components. If executing this statement results in the error “% Error opening file.”,
then the “IDL_QS_Files/lib/” subfolder that contains this batch file is not included in IDL’s path. Please go
back to chapter 1 of this Quick Start tutorial and perform the steps delineated in the section entitled
“Installing the Tutorial Files” in order to rectify this problem.
12. Select the file named “St_Louis.jpg” and press the “Open” button.
A new Direct Graphics display window entitled “Full Resolution Zoom (click with left
or right mouse button)” will appear with the image graphic. This display window
allows the user to click-and-drag with either the left (200 x 200 zoom window) or
right (400 x 400 zoom window) mouse button in order to display the current image
area at full resolution.
13. Experiment with clicking both the left and right mouse buttons within the
image display window [Fig. 9-4].
Figure 9-4: Direct Graphics image display with rapid overlay capabilities
14. Once finished viewing the image of St. Louis, close the Full Resolution Zoom
display window.
The following exercise illustrates another powerful aspect of the Direct Graphics
system by loading a series of images into IDL and displaying each in a sequential
fashion. The delay between the display of each image in the sequence is so short
that the visualization has the appearance of an animation (i.e. movie) to the viewer.
IDL has a pre-built utility that provides an interface and controls for viewing
animations called XINTERANIMATE. This utility utilizes the Direct Graphics system to
display images in a very rapid fashion.
The images that will be loaded as movie frames into this animation utility are located
in the “frames” subfolder of the “data” subfolder of the Quick Start directory :
• Windows: C:\RSI\IDL##\IDL_QS_Files\data\frames\*
• UNIX et al.: /usr/local/rsi/idl_#.#/IDL_QS_Files/data/frames/*
• Mac OS X: /Applications/rsi/idl_#.#/IDL_QS_Files/data/frames/*
The individual data files found in this “frames” subfolder are in BMP format. Start by
selecting this folder and inputting the images into the current IDL session. The
DIALOG_PICKFILE function can be used to display the native file selection dialog.
Set the DIRECTORY keyword so the dialog prompts the user to select an entire folder
instead of individual files :
Confirm that the selected folder was successfully returned as a string into the named
variable “folder” :
Note: The string value for the “folder” variable may be different depending on the installation location for
the IDL software.
Next, utilize the FILE_SEARCH function in order to determine the full path to each of
the individual 116 BMP format files located within the “frames” subfolder :
Obtain information on the image data for the first BMP file in the sequence using the
QUERY_BMP function :
The contents of the information structure returned by QUERY_BMP illustrate that the
image data is of type byte and has a size of 320 columns by 240 rows with 3 color
channels. Initialize a new variable named “frames” that will be used to store all of
the images in the sequence :
Now that a variable has been initialized within the current IDL session to store all of
the images in the sequence, they can be input from their individual BMP format files.
Utilize the FOR loop control statement to read-in the images from all of the files into
the appropriate index of the “frames” variable :
Finally, load the image frames into the XINTERANIMATE visualization utility. This is
accomplished by calling the XINTERANIMATE procedure 3 times; first to initialize the
utility, second to load the individual image frames, and third to actually launch the
display window.
The extremely fast display speed of the Direct Graphics system can be seen by
changing the “Animation Speed:” slider to its highest setting :
29. Click on the vertical bar within the “Frames/Sec:” slider and drag it all the
way to the right in order to obtain the maximum setting.
Notice how fast the animation utility is able to update the image display.
30. Once finished viewing the animation, close the XInterAnimate window.
IDLxxYyyy
where xx represents the broad functional grouping (gr for graphics objects, db for
database objects, an for analysis objects, ff for file format objects, etc.). Yyyy is the
class name itself (such as Axis or Surface). For example, the IDLgrAxis object
provides an encapsulation of all of the components associated with a graphical
representation of an axis.
IDL objects are actually special variables known as heap variables, which means
that they are global in scope and provide explicit user control over their lifetimes.
Object heap variables can only be accessed via object references. In order to
perform an action on an object’s instance data (such as the modification of
attributes), you must call one of the object’s methods. To call a method, you must
use the method invocation operator “->” (the hyphen followed by the greater-than
sign). The syntax is :
ObjRef->Method
where ObjRef is an object reference and Method is a method belonging either to the
object’s class or to one of its superclasses. The method may be specified either
partially (using only the method name) or completely using both the class name and
method name, connected with two colons :
ObjRef->ClassName::MethodName
In order to utilize Object Graphics, the user must build a self-contained hierarchy of
the appropriate objects that is subsequently drawn to a destination object. The 5
primary building blocks of an Object Graphics visualization are :
For example, in the following exercise a hierarchy of objects will be created that
contain a simple line plot visualization, and this hierarchy will be drawn to a display
window destination object :
2. Create an instance of the IDLgrPlot object class for this data using the
OBJ_NEW function. The object reference for this line plot is returned into the
variable named “oPlot” :
3. Create an IDLgrModel object and execute the “Add” method in order to add
the line plot object to the model. Once this is accomplished, the model object
will contain the plot object :
A simple black line plot will be drawn on top of the white view within the Object
Graphics window. Much like Direct Graphics, this is a static display window that does
not expose any interactive manipulation capabilities. Furthermore, the visualization
does not include axes because instances of the IDLgrAxis class were not explicitly
added to the object hierarchy. In order to make modifications to this visualization,
such as changing the color and adding an axis, the appropriate object must be
created and the SetProperty method must be utilized on the existing objects. For
example, the background color can be changed to yellow, the line plot color to blue,
and an X axis inserted into the visualization by executing the following statements :
Since IDL objects are stored as heap variables, they persist in memory until they are
explicitly destroyed. Information on all of the current heap variables that exist
within an IDL session can be obtained by executing the HELP procedure with the
HEAP keyword set :
The output from the HELP procedure illustrates that a number of objects and pointers
have been created and are currently using memory within the current IDL session.
In order to destroy all of the heap variables associated with this visualization and
free the memory that is currently being used, the OBJ_DESTROY procedure must be
used in order to complete the object life cycle :
Notice that destroying the top level object in a hierarchy (the view object in this
case) destroys all of the other objects it contains. Once this is accomplished,
another call to the HELP procedure should show that all of the heap variables have
been destroyed (and the memory they were using released) :
One of these utilities is called XDXF, and it is used to visualize geometric shapes
stored in AutoCAD DXF format files as 3-Dimensional polygonal objects. Another
more generic utility called XOBJVIEW can be used to quickly and easily visualize and
manipulate Object Graphics on screen. In the following exercise, a geometry from
the example data file “F-14.dxf” will be input into both of these utilities. This
example data file is located in the “data” subfolder of the Quick Start directory :
• Windows: C:\RSI\IDL##\IDL_QS_Files\data\F-14.dxf
• UNIX et al.: /usr/local/rsi/idl_#.#/IDL_QS_Files/data/F-14.dxf
• Mac OS X: /Applications/rsi/idl_#.#/IDL_QS_Files/data/F-14.dxf
This dataset contains the vertices and polygonal connectivity to define the three-
dimensional geometry for a F-14 fighter jet. Start by launching the XDXF utility :
Since no filename was specified, a native file selection dialog will appear entitled
“Select DXF File to Read”.
17. Select the “F-14.dxf” file and press the “OK” button.
18. Once finished viewing the 3-D geometry visualization, close the XDXF
Information window.
Within the XDXF utility, the geometry object is displayed by default with flat shading
and the vertex colors that are defined by the DXF file (in this case, all white). There
is no way to modify the appearance of the object unless the properties of the
underlying polygonal mesh object itself are modified. In order to give the geometry
object a more genuine appearance similar to that of a real F-14 fighter jet, the
Object Graphics components must be built manually.
In addition to graphical object classes, IDL also contains several file format objects
that are used to read and write data to files on disk. The DXF file format is one that
is handled using an object class in the IDL software package. The object class is
named “IDLffDXF”, and it can be utilized to input the data from the file “F-14.dxf”
file. Start by using the DIALOG_PICKFILE function to display the native file selection
dialog and select the “F-14.dxf” file on the harddrive :
Note: The string value for the “file” variable may be different depending on the installation location for
the IDL software.
Next, create an instance of the IDLffDXF object class and read-in the entity list by
executing the Read method :
Obtain the contents of the DXF file and filter the result so it only contains “FACE3D”
entity types by setting the filter argument equal to 10 while executing the
GetContents method :
Once the contents have been determined, the actual data can be read-in by
executing the GetEntity method :
Make sure to destroy the object and free the heap memory :
The vertices and polygonal connectivity can be extracted from the structure by
dereferencing their respective pointers :
Once the polygon object has been created, change some of the properties to modify
the appearance of the geometry so it looks more like a grayish-blue metal aircraft :
Now that the polygon object has been created and its properties modified, it can be
visualized in the generic XOBJVIEW utility :
You can rotate the image, zoom in and move it within the window. The resulting
visualization window should look similar to Fig. 9-9.
37. Once finished viewing the polygon object, close the Xobjview window.
Another powerful aspect of the Object Graphics system is that most of the atomic
graphic objects have a property named either ALPHA_CHANNEL or
BLEND_FUNCTION that can be used to apply a transparency effect to the
visualization. This allows the user to create composite visualizations with more than
one object that involves an opacity adjustment in order to see through certain
objects. An example of this methodology is provided in the program named
ALPHA_BLENDING, which uses 2 images stored in the file “pictures.sav” located in
the “data” subfolder of the Quick Start directory :
• Windows: C:\RSI\IDL##\IDL_QS_Files\data\pictures.sav
• UNIX et al.: /usr/local/rsi/idl_#.#/IDL_QS_Files/data/pictures.sav
• Mac OS X: /Applications/rsi/idl_#.#/IDL_QS_Files/data/pictures.sav
The file is in IDL save file format and contains two color photographs from Arches
National Park. Start by launching the custom program :
A standard native file selection dialog will appear entitled “Select “pictures.sav” file
to open”.
39. Select the file named “pictures.sav” and press the “Open” button.
A new Object Graphics display window will appear that shows a gradual transition
from one image to the next and back again [Fig. 9-10].
40. Once finished viewing the images, close the IDL Object Window 32 window.
41. Before moving on to the next chapter, it is a good idea to reset the IDL
session. This can be accomplished by executing the statement :
IDL> .reset_session
There are several different ways in which a computer program can be created, and
IDL supports the development of programs using a wide variety of methodologies.
There are 5 primary types of IDL programs :
• Batch Files
• Main-Level Programs
• Named Programs (procedures & functions)
o Object-Oriented Programs (creating IDL objects and their methods)
o iTools System Programs
Batch Files
A batch file contains one or more IDL statements or commands. Each line of the
batch file is read and executed before proceeding to the next line. This makes batch
files different from main-level programs, which are compiled as a unit before being
executed, and named programs, in which all program modules are compiled as an
unit before being executed. Batch files are sometimes referred to as include files,
since they can be used to include the multiple IDL statements contained in the file in
another program.
In the following exercise, a simple batch file is created and executed using the at
symbol (“@”) special character. The “@” symbol is either used as an include
character within other programs or to signal that batch processing is to be
performed. Executing the “@” symbol followed by the path to a batch file on disk
will execute all of the statements within the batch file, one line at a time, in a
sequential fashion.
1. Start by selecting “File > New > Editor” from the main IDL Development
Environment menu system. This will open a new blank text editor window in
the document panel of the IDLDE.
2. Within the text editor window, enter the following IDL code :
3. Once these 3 lines of IDL code have been entered, select “File > Save As…”
from the menu system.
4. Save the text to a new file named “batch.pro” located in the “output”
subfolder of the Quick Start directory :
• Windows: C:\RSI\IDL##\IDL_QS_Files\output\batch.pro
• UNIX et al.: /usr/local/rsi/idl_#.#/IDL_QS_Files/output/batch.pro
IDL> @batch
This will execute each of the 3 lines from the batch file in sequence as if they were
executed individually at the IDL> command prompt. The resulting iImage
visualization window should look similar to Fig. 10-1.
6. Once finished viewing the image, close the IDL iImage window.
7. Select “File > Close” in order to close the text editor window for this batch
file.
Main-Level Programs
Main-level programs are entered at the IDL command line, and are useful when
you have a few commands you want to run without creating a separate file to
contain your commands. Main-level programs are not explicitly named; they consist
of a series of statements that are not preceded by a procedure or function heading.
IDL> a = 3
2. Next, execute the .RUN executive command. This changes the command
prompt from “IDL>” to “-” :
IDL> .RUN
a = a ^ 2
PRINT, a
END
5. This main-level program can be run again by executing the .GO executive
command :
IDL> .GO
81
Procedures and functions are self-contained modules that break large tasks into
smaller, more manageable ones. A procedure is a self contained sequence of IDL
• Automatically : If the ASCII text source code file for the program has a
filename that is identical to the name of the main program module, the
filename ends with a “.pro” extension, and this file is found within IDL’s path,
then the program will be automatically compiled when it is executed. For
reference, IDL’s path is one of the Preferences found within the IDL
Development Environment, and it is also stored in an internal system variable
named !PATH.
• Interactively : If the source code file for the program is currently open within
the text editor of the IDL Development Environment, the user can either
select “Run > Compile” from the menu system or press the yellow
compile button on the toolbar in order to compile the program.
• Manually : The user can explicitly compile a program by executing the
.COMPILE, .RUN, or .RNEW executive commands with the appropriate path to
the source code file on disk. If the source code file is found within IDL’s path
or the current working directory, then just the name of the file itself is
needed. If the user is working within the IDL Development Environment, the
source code will automatically be opened into the text editor window.
1. Start by selecting “File > New > Editor” from the main IDL Development
Environment menu system. This will open a new blank text editor window in
the document panel of the IDLDE.
2. The first step in writing a procedure is to create the definition statement,
and this is accomplished using the PRO statement in IDL. In this case, the
name given to the procedure will be “muscle_view”, so start by typing the
following text in the blank text editor window :
PRO muscle_view
At this point, the name of the current text document is probably [Untitled1*] and it
is not being saved to the harddrive, so it may be appropriate to save this text to an
IDL source code file on disk.
• Windows: C:\RSI\IDL##\IDL_QS_Files\output\muscle_view.pro
• UNIX et al.: /usr/local/rsi/idl_#.#/IDL_QS_Files/output/muscle_view.pro
• Mac OS X: /Applications/rsi/idl_#.#/IDL_QS_Files/output/muscle_view.pro
Once this is accomplished, the title bar across the top of the IDL Development
Environment should be labeled with “[muscle_view.pro]”. Whenever a change is
made to the file an asterisk “*” character will be added to the end of the filename,
alerting the user that the file contains modifications that have not yet been saved to
the file on disk. Changes to the source code file can be saved by selecting “File >
Save” from the IDLDE menu or by pressing the button on the IDLDE toolbar.
5. The first step within the program that needs to be entered on the next line of
the text editor is the specification of the path to the file that is going to be
opened :
7. The QUERY_JPEG function returns a value of “1” into the result if the query
was successful and the file appears to be a valid JPEG format image file,
otherwise it returns “0” upon failure. Consequently, it may be a good idea to
terminate the execution of this program at this point using the RETURN
procedure if the file is not determined to be a valid JPEG image file :
8. Now the JPEG image file data can be read into this IDL program unit using the
READ_JPEG procedure :
9. An IDL graphics window needs to be created to display this image, and the
size of this window can be made to match the size of the image using the
“info” structure returned by the earlier call to QUERY_JPEG :
10. Next, the use of color decomposition must be disabled in order to use IDL’s
built-in colortables on 24-bit displays :
device, decomposed=0
11. In order to loop through each of IDL’s predefined colortables and display the
image data insert the following lines of text :
for i = 0, 40 do begin
loadct, i
tvscl, image
endfor
This will cycle through the variable “i” set to values 040, load the colortable index
for the current FOR loop iteration value of “i” using LOADCT, display the image using
TVSCL, increment the variable “i” by a value of 1, and start the next iteration.
12. Once the FOR loop has executed, the graphics window that was created can
be cleaned up and destroyed by calling the WDELETE procedure :
wdelete
13. Finally, the end of the program must be defined by inserting the END
statement :
END
14. Once all of this text has been entered make sure to select “File > Save” or hit
the button on the IDLDE toolbar.
The final program within the text editor window should look similar to Fig. 10-2.
15. In order to compile the procedure, simply select “Run > Compile
muscle_view.pro” from the main IDLDE menu system or hit the yellow
compile button on the toolbar. This will automatically call the executive
command .COMPILE and the output log should read :
If there are any compilation errors an informational message will appear in the
output log and a red circular dot will be placed to the left of the line where the error
occurs. Any compilation errors must be resolved before the program can be
executed.
IDL> muscle_view
During execution of the program the “muscle.jpg” image will be displayed using all
41 of IDL’s built-in colortables [Fig. 10-3]. While the program is executing the
LOADCT procedure will output the currently loaded colortable to the output log when
it’s being called within the FOR loop. The total time it takes for this program to
execute should be very short, which is a testament to the rapid image display
capabilities of the Direct Graphics system and the overall speed of the IDL language.
17. Select “File > Close” in order to close the text editor window for this
procedure.
In the next exercise a simple function will be created that computes the area of a
circle given its radius. Functions are slightly different from procedures because they
must return a specific value to the calling module. Consequently, functions are
particularly useful when performing data processing and analysis. In addition, as
previous exercises within this tutorial have illustrated, the calling syntax for
executing functions is different than procedures.
18. Start by selecting “File > New > Editor” from the main IDL Development
Environment menu system. This will open a new blank text editor window in
the document panel of the IDLDE.
Once again, the first step in writing a function is to create the definition
statement, and this is accomplished using the FUNCTION statement in IDL. In this
case, the function will need to accept an argument in order to allow passing of the
input radius value into the program. Furthermore, the user may wish to specify
whether they want the calculation performed using single-precision or double-
precision floating-point arithmetic. This can be accomplished by specifying a
keyword that the user can utilize in order to control the behavior of the function.
19. The name given to the function will be “circle_area”, the input argument
should be named “radius”, and a keyword named “dbl” can be declared so the
Once again, it is a good idea to save this text to an IDL source code file on disk :
20. From the main IDLDE menu system select “File > Save As”.
21. Save the text to a new file named “circle_area.pro” located in the “output”
subfolder of the Quick Start directory :
• Windows: C:\RSI\IDL##\IDL_QS_Files\output\circle_area.pro
• UNIX et al.: /usr/local/rsi/idl_#.#/IDL_QS_Files/output/circle_area.pro
• Mac OS X: /Applications/rsi/idl_#.#/IDL_QS_Files/output/circle_area.pro
22. The KEYWORD_SET function built into the IDL language library is useful for
determining the status of a keyword variable and whether or not it was “set”
by the user. In this case, a variable named “dbl” exists within the function
and either has a value of 1 if it was set, or 0 if it was left un-set. The
KEYWORD_SET function can be used in conjunction with an IF … THEN …
ELSE code block to perform the necessary calculation using the appropriate
IDL system variable for the value of ∏ :
23. Once the area has been computed using the appropriate precision, the “area”
variable can be returned to the calling program module :
return, area
24. Finally, the end of the program must be defined by inserting the END
statement :
END
25. Once all of this text has been entered make sure to select “File > Save” or hit
the button on the IDLDE toolbar.
The final program within the text editor window should look similar to Fig. 10-4.
26. In order to compile the function, simply select “Run > Compile
circle_area.pro” from the main IDLDE menu system or hit the yellow
compile button on the toolbar. This will automatically call the executive
command .COMPILE and the output log should read :
If there are any compilation errors an informational message will appear in the
output log and a red circular dot will be placed to the left of the line where the error
occurs. Any compilation errors must be resolved before the program can be
executed.
Once the program is successfully compiled it can be executed by calling it with the
appropriate function syntax :
This statement calls the “circle_area” function and specifies an input radius value of
seven. The named variable “area” contains the result of this calculation that is
returned from the function :
In addition, the “circle_area” function can be called with the “dbl” keyword set in
order to compute the area in double-precision :
The “area” variable that is returned from the function is now double-precision.
31. Once finished experimenting with the “circle_area” function, select “File >
Close” in order to close the text editor window.
IDL objects may contain data with various data types or organizational arrangement.
The routines (i.e. functionality) within an object that act upon this data are called
methods. Object methods are merely IDL procedures and functions that have
special names and are called in a special way. In the IDL programming
environment, object data are protected from the rest of the program and are only
accessible through the object methods (i.e. IDL object data is always private).
IDL’s object system provides support for the following concepts and mechanisms:
• Define the object class data structure by creating a named structure. The
name of this structure must be the same as the desired name for the object
PRO SHOW3OBJ::Display
if ptr_valid(self.data) then show3, *self.data
END
Once the object class has been defined an instance of the object can be created
using the OBJ_NEW function :
The Display method to this object can then be executed using IDL’s method
invocation operator (“->”), which is a hyphen followed by a greater-than sign :
In this example the Display method is a procedure, but methods can also be
functions. If an object method is defined as a function then its calling sequence will
be :
Once an object has data assigned to it, the methods automatically have access to
this data in a structure called “self” that has the same layout as the original object
class data structure. Consequently, there is no need to pass the data via arguments
and/or keywords in the call to an object method. In addition, the self structure can
be used to call other methods within an object. For instance, if there was a
LOADCOLOR method to the SHOW3OBJ object class it could directly call the DISPLAY
method using the self structure :
When an instance of an object is created from a class using the OBJ_NEW function
an object reference is returned that points to an object heap variable [Fig. 10-5].
A heap variable is an area of common memory allocated for a specific use and
accessed by way of one or more reference variables. These reference variables are
the means through which the object is referenced in IDL.
OBJ_DESTROY, oShow3
Once the OBJ_DESTROY procedure is called the object heap variable for this object
no longer exists, but the object reference variable oShow3 still exists and points to a
non-existent piece of memory. This is known as a dangling reference.
Consequently, it is always a good idea to also destroy all object reference variables
when destroying an object by either using the DELVAR procedure (interactive IDL
only) or the TEMPORARY function:
OBJ_DESTROY, TEMPORARY(oShow3)
In order to create an object class in IDL there are a set of programming rules that
must be followed when writing the source code. Selecting a name for a custom
object class is a very important consideration because it is important not to use the
same name as a class already built into IDL. Fortunately, most object classes built
When creating a custom object class in IDL a special naming convention must be
used for the source code file name and the procedure/function names within that
source code file. As mentioned before, the general form for the procedure/function
declaration statements within the object class source code is “CLASSNAME::method”.
In addition, there is also a naming convention for the source code file itself that
follows the general form “CLASSNAME__method” (Note: “__” is two underscores).
The information necessary for the object must be defined in the object class data.
When defining the data of an object, the programmer must determine in advance all
of the various data elements that might be necessary to complete all of the
functionality for the object. As mentioned earlier, the object class data is defined
and stored in an IDL named structure that has the same name as the class itself.
This is the first step in creating an object class and it occurs within a special
procedural method called “DEFINE”. Consequently, in order for IDL to create an
instance of an object with OBJ_NEW an IDL source code file for this object with the
name “CLASSNAME__define.pro” must be found in the !PATH (or manually compiled
within the current session of IDL). The define method is also the only method which
uses the two underscores (“__”) in the procedural declaration statement as opposed
to the two colons (“::”). For example, the source code to define the SHOW3OBJ
object class above would look like:
PRO SHOW3OBJ__define
namedStructure={SHOW3OBJ, data:ptr_new()}
END
Once the data has been defined for an object class, the next step is to create the
methods that will define the functionality. These methods can be stored in separate
“CLASSNAME__method.pro” ASCII source code files, or they can all be stored in the
main “CLASSNAME__define.pro” file as long as the __define procedure is the last
module that occurs within the file.
There are also 2 other methods that must be included with every object class: INIT
and CLEANUP. The 3 main object methods (DEFINE, INIT, CLEANUP) must be
defined and compiled within IDL before an instance of the object can be created with
OBJ_NEW. The INIT method is an IDL function that is called by OBJ_NEW when the
object is created. The job of the INIT method is to take any arguments and
keywords passed from the user and perform any initialization necessary for the
object class. The process of initialization usually involves filling-in the members of
the object data structure with the data passed by the user in the call to OBJ_NEW.
Finally, the INIT method should return 1 if successful in initializing the object and 0 if
the initialization failed. In contrast, the CLEANUP method is called when the object
reference is destroyed (when OBJ_DESTROY is executed)) and should clean up any
pointers, objects, or other miscellaneous data in an effort to avoid memory leakage.
1. Start by selecting “File > New > Editor” from the main IDL Development
Environment menu system. This will open a new blank text editor window in
the document panel of the IDLDE.
2. Immediately select “File > Save As” and save this to a file called
“show3obj__define.pro” located in the “output” subfolder of the Quick Start
directory :
• Windows:
C:\RSI\IDL##\IDL_QS_Files\output\show3obj__define.pro
• UNIX et al.:
/usr/local/rsi/idl_#.#/IDL_QS_Files/output/show3obj__define.pro
• Mac OS X:
/Applications/rsi/idl_#.#/IDL_QS_Files/output/show3obj__define.pro
3. Type out the source code for this object class in the IDLDE text editor. There
will be a total of 5 methods defined for the SHOW3OBJ object class: DEFINE,
INIT, CLEANUP, LOADCOLOR, and DISPLAY. Make sure to remember the rule
of placing the __define procedure at the bottom of this file :
PRO SHOW3OBJ::Cleanup
ptr_free, self.data
print, 'SHOW3OBJ object successfully destroyed.'
END
PRO SHOW3OBJ::Display
if ptr_valid(self.data) then show3, *self.data
END
PRO SHOW3OBJ__define
namedStructure = {SHOW3OBJ, data:ptr_new()}
END
4. Once all of this source code has been entered into the text editor, save the
file and then compile the object class by pressing the yellow compile
button. This should report the following in the IDL Output Log :
Now that the object class is compiled within the current session of IDL it is ready to
be used. Initialize an instance of the SHOW3OBJ object class with data created by
the DIST function :
The resulting IDL 0 visualization window should contain a composite 3-D visualization
including an image, wire-mesh surface, and contour plot produced by IDL’s built-in
SHOW3 routine.
The Loadcolor method can also be executed to load IDL’s Rainbow colortable and
automatically redisplay the graphic:
Once the user is finished working with the object it is important to destroy the heap
variable and object reference:
However, iTools are much more than just a set of pre-written IDL programs. Behind
the iTool system lies the IDL Intelligent Tools Component Framework — a set of
object class files and associated utilities designed to allow you to easily extend the
supplied toolset or create entirely new tools of your own. The iTools component
In addition, the iTools component framework makes it easy to extend the system
with components of your own creation, allowing you to design a tool to manipulate
and display your data in any way you choose. Programming in the iTools system
allows the user to create their own :
• iTool
• Visualization
• Operation
• Manipulator
• File Reader
• File Writer
• Graphical User Interface
A discussion of programming within the iTools system is beyond the scope of this
tutorial. For more information please consult the iTool Developer’s Guide
documentation manual included with the IDL online help system [Fig. 10-7].
IDL widgets are significantly easier to use than other alternatives, such as writing a
C language program using the native window system graphical interface toolkit
directly. IDL handles much of the low-level work involved in using such toolkits. The
interpretive nature of IDL makes it easy to prototype potential user interfaces. In
addition to the user interface, the author of a program written in a traditional
compiled language also must implement any computational and graphical code
required by the program. IDL widget programs can draw on the full computational
and graphical abilities of IDL to supply these components.
The style of widgets IDL creates depends on the windowing system supported by
your host computer. Unix hosts use Motif widgets, while Microsoft Windows systems
use the native Windows toolkit. Although the different toolkits produce applications
with a slightly different look and feel, most properly-written widget applications work
on all systems without change.
Programs that use widgets are event driven. In an event driven system, the
program creates an interface and then waits for messages (events) to be sent to it
from the window system. Events are generated in response to user manipulation,
such as pressing a button or moving a slider. The program responds to events by
carrying out the action or computation specified by the programmer, and then
waiting for the next event. Because of widget applications’ event-driven nature,
creating applications that use widgets is fundamentally different from creating non-
widget programs.
The following exercise creates a very simple graphical user interface application with
the appropriate event handling sub-program. This program displays a simple GUI
with a button labeled “Display Image” that can be pressed by the user in order to
generate an event that display an image from an example file included with IDL.
1. Start by selecting “File > New > Editor” from the main IDL Development
Environment menu system. This will open a new blank text editor window in
the document panel of the IDLDE.
2. Immediately select “File > Save As” from the menu system and save this
document to a file called “simple_gui.pro” located in the “output” subfolder of
the Quick Start directory :
• Windows: C:\RSI\IDL##\IDL_QS_Files\output\simple_gui.pro
• UNIX et al.: /usr/local/rsi/idl_#.#/IDL_QS_Files/output/simple_gui.pro
• Mac OS X: /Applications/rsi/idl_#.#/IDL_QS_Files/output/simple_gui.pro
3. Type out the source code for this widget program into the IDLDE text editor :
PRO simple_gui
tlb = widget_base(/row, title='Simple GUI')
subBase=widget_base(tlb)
button = widget_button(subBase, value='Display Image')
draw = widget_draw(tlb, xsize=512, ysize=512)
widget_control, tlb, /realize
file = filepath('elev_t.jpg', subdir=['examples', 'data'])
read_jpeg, file, image
device, decomposed=1
state = {image:image}
widget_control, tlb, set_uvalue=state
xmanager, 'simple_gui', tlb
END
This program contains 2 modules; the main GUI creation procedure named
“simple_gui”, and the event handler procedure called “simple_gui_event”. Within
4. Once the source code for the program has been entered, save the changes by
pressing the button on the IDLDE toolbar.
5. Compile the program by pressing the yellow compile button.
6. Finally, run the program by pressing the blue run button.
7. Once the GUI for the program is displayed, use the mouse to press the
“Display Image” button [Fig. 10-8].
8. Once finished viewing the simple widget application, close the Simple GUI
window.
IDL has an architectural (and distribution) paradigm that is very analogous to Java
since they are both interpreted computer languages. There are basically 3 different
varieties of the IDL software package that can be used to execute programs written
in the IDL language :
The primary difference between these varieties of IDL is that the full developer’s
copy allows the user to create, edit, modify, compile, execute, and save IDL
programs. In contrast, both the IDL Runtime and IDL Virtual Machine versions of
IDL can only be used to execute pre-compiled runtime binary versions (*.sav file) of
a program. Consequently, users of the IDL Runtime or the IDL Virtual Machine
cannot modify the IDL programs that are being executed.
In the following exercise, the “muscle_view” program that was created earlier will be
compiled and saved out to a runtime binary file on disk that can be executed in
either IDL Runtime or the IDL Virtual Machine. This can be accomplished with the
SAVE procedure, which is used to save either data variables or the compiled routines
within the current software session to IDL’s proprietary binary save file format. The
IDL save file format is encrypted (and is not documented) so it is impossible to
reverse-engineer a program stored in a “*.sav” file and obtain the original source
code. Calling the SAVE procedure with the ROUTINES keyword set will save all
currently compiled user-defined procedures and functions within the current IDL
session. Consequently, it is a good idea to reset the IDL session and start fresh so
that none of the other programs that have been compiled thus far are included in the
save file that is created :
1. IDL> .reset_session
Next, compile the “muscle_view” program that was created in the earlier exercise by
utilizing the .COMPILE executive command :
The Runtime and Virtual Machine versions of the software are basically the IDL
interpreter provided in a series of library files. This interpreter includes all of the
internal system routines within the IDL language. However, it does not include the
routines within the IDL library that are written in IDL itself and are distributed as
source code *.pro files in the “lib” subfolder of a developer’s copy installation. For
example, the FILEPATH function from the IDL library that this “muscle_view”
program utilizes is actually distribute with the software in the following source code
file :
• Windows: C:\RSI\IDL##\lib\filepath.pro
• UNIX et al.: /usr/local/rsi/idl_#.#/lib/filepath.pro
• Mac OS X: /Applications/rsi/idl_#.#/lib/filepath.pro
When the “muscle_view” program is executed within a full developer’s copy of IDL,
the “filepath.pro” source code file is automatically located and compiled on-the-fly
because the “lib” subfolder of the installation is part of the default path. Since the
Runtime and Virtual Machine versions of IDL cannot compile programs from their
ASCII text source code, these routines cannot be distributed in their original *.pro
file form. Consequently, the programmer must be sure to resolve and compile all of
the external IDL routines that their program utilizes that are not internal system
routines built into the interpreter libraries. Fortunately, IDL contains a convenient
procedure that can be used by the IDL programmer in order to resolve all of these
dependencies named RESOLVE_ALL :
3. IDL> RESOLVE_ALL
% Compiled module: RESOLVE_ALL.
% Compiled module: LOADCT.
% Compiled module: FILEPATH.
% Compiled module: PATH_SEP.
% Compiled module: UNIQ.
Notice that the RESOLVE_ALL procedure will locate and compile not only the LOADCT
and FILEPATH routines from the IDL library that this program explicitly calls, but will
also resolve any subsequent routines that these programs happen to call that are not
already compiled (in this case, PATH_SEP and UNIQ). Under initial inspection, it may
not be obvious to the programmer that this “muscle_view” program relies on the
PATH_SEP and UNIQ routines from the external IDL library because they do not
explicitly appear within the program, and this is the benefit of utilizing the
RESOLVE_ALL procedure when creating distributable applications.
Finally, the SAVE procedure can be called with the ROUTINES keyword set in order to
save all of the currently compile procedures and functions to an IDL runtime binary
save file. Use the FILE keyword to specify the appropriate output filename, which is
the name of the primary program module followed by a .sav extension :
• Windows: C:\RSI\IDL##\IDL_QS_Files\output\muscle_view.sav
• UNIX et al.: /usr/local/rsi/idl_#.#/IDL_QS_Files/output/muscle_view.sav
• Mac OS X: /Applications/rsi/idl_#.#/IDL_QS_Files/output/muscle_view.sav
5. Navigate to this “output” folder and attempt to locate the file named
“muscle_view.sav”. If this file is not found within the “output” folder, then
execute the following IDL statements in order to determine the current
working directory and locate the “muscle_view.sav” file :
6. Once the “muscle_view.sav” file has been located, it can be executed within
IDL Runtime using the appropriate execution methodology based on operating
system :
idl –rt=muscle_view.sav
Once this is accomplished a new IDL process will launch, the “muscle_view” program
will be executed, and the IDL process will shut-down.
7. Finally, the same program can be executed within the IDL Virtual Machine by
performing the following steps :
• Windows: Select “Start > Programs > RSI IDL #.# > IDL Virtual Machine”.
• UNIX, Linux, & Mac OS X: At a shell or X11 terminal prompt, navigate to
the folder that contains the “muscle_view.sav” file and execute the following
command :
idl –vm=muscle_view.sav
8. The IDL Virtual Machine splash screen will appear, and the user must click on
this splash screen in order to continue.
9. On Windows, the user will be prompted with a dialog to select the
“muscle_view.sav” program file on the harddrive.
Once this is accomplished a new IDL process will launch, the “muscle_view” program
will be executed, and the IDL process will shut-down.
Techniques for writing efficient programs in IDL are identical to those in other
computer languages, with the addition of the following simple guidelines :
• Use vector and array operations rather than loops wherever possible.
• Try to avoid loops with high repetition counts.
• Use IDL system functions and procedures wherever possible.
• Access array data in machine address order (IDL is row-major).
• Pay attention to expression evaluation order.
• Avoid IF … THEN … ELSE code block statements if possible, especially within
loops.
• Use only the highest precision (variable data types) necessary during
computations.
• Eliminate invariant expressions.
• Make use of the TEMPORARY function.
• Utilize the IDL Code Profiler.
Attention also must be given to algorithm complexity and efficiency, as this is usually
the greatest determinant of resources used. For a more detailed discussion on the
subject of writing efficient IDL programs (along with some code examples), please
consult the Building IDL Applications documentation manual included with the IDL
online help system [Fig. A-1].
The various methods for calling external software components from IDL are :
In contrast, the LINKIMAGE procedure provides a way to load external C code into
IDL and declare it in a manner so it appears as if it were part of the IDL internals.
That way, you can execute your external code as if it were an IDL routine built into
IDL, with the same calling sequence syntax as any other IDL function. An obvious
caveat is that you must declare it with a name that does not conflict with any of the
routine names already built into IDL. The LINKIMAGE procedure must “link in” this
code in any given IDL session before the routine can be used, so it is a good idea to
perform this linking in an IDL startup file.
The IDL-Java Bridge allows users to access Java objects within their IDL code,
which enables you to take advantage of functionality provided by Java, including
Java I/O, networking, and third party functionality. The IDLjavaObject class
instantiates a desired Java object using the object’s class name. An instance of this
object within IDL allows you access methods and data members (properties) of the
desired Java object. To the IDL user, an instance of the IDLjavaObject class behaves
just like any other IDL object. When an instance of the IDLjavaObject class is
created, the IDL-Java bridge connects that instance to a Java object. This initial
connection starts a Java session. In IDL, you can monitor the session through the
IDLJavaBridgeSession object. This object can be used to handle any exceptions
(caused by the Java object) within IDL. Currently, the IDL-Java bridge is supported
on the Windows, Linux, Solaris, and Macintosh platforms supported in IDL.
IDL is packaged in a shareable form that allows other programs to call IDL as a
subroutine using a mechanism known as Callable IDL. This shareable portion of
IDL can be linked into your own programs written in C, C++, FORTRAN, etc.. With
this mechanism, all the functionality of the IDL interpreter is usable and presented to
the programmer as a library of commands. The actual functionality is linked into the
external program at run-time via the shared resource, such as a dynamic link library
on Windows. For example, within a C program, IDL statements can be executed
using IDL_ExecuteStr :
This code creates an IDL variable called “tmp” and plots the sine of “tmp”, just as if
these commands were executed directly at an IDL> command prompt.
The Remote Procedure Call mechanism allows IDL to be run as an RPC server on
UNIX platforms. In other words, your program runs as an RPC client. It can execute
procedure and function calls as if it were in the same memory space as the server.
However, these two programs may be on entirely separate machines connected via a
network. The commands are actually executed on the server machine. Variables
can be created on the client and sent to the server, and variables created on the
server can be sent to the client. With this method, you have access to the power of
the server machine from a client machine.
IDL has been built into an ActiveX Control, which allows programs enabled with the
ActiveX technology to access IDL functionality. This allows IDL functionality to be
embedded into Windows applications and programming environments such as Visual
Basic and Visual C++. When the ActiveX control is embedded, all the analysis and
graphics capabilities of IDL become available to the application. The ActiveX control
in IDL is presented in the form of the IDLDrawWidget object class. ActiveX is a
technology that defines a standard way of embedding and controlling foreign
components into applications on Window platforms. ActiveX is a Microsoft term for
this set of technologies and services that are all based on the common object model
(COM). There are several variations of ActiveX including ActiveX Documents, ActiveX
Scripting, and ActiveX Controls. All variations of ActiveX are an outgrowth of
Microsoft’s Object Linking and Embedding (OLE), which defines a common interface
for including foreign software components in applications.
ION (IDL On the Net) is a plugin for IDL. ION is a family of products that allow you
to run your IDL applications in a networked environment, giving Intranet or Internet
users access to IDL visualization and analysis. The primary design of this plugin is
focused on a client-server environment that involves a web browser. There are 2
versions of the ION plugin. "ION Script" is a tool that includes a powerful tag-based
language (similar to HTML) to publish IDL visualizations, analyses, and interactive
applications on a webpage. "ION Java" can be used to create either Web-based, or
entirely self-contained, distributable Java applications. ION Java combines both IDL
and Java into a single, powerful tool for building client-server Java applications and
Web applets. ION Java includes a low-level Java class library, pre-built Java applets,
and mid-level component classes that provide you with the ability to create
sophisticated Java applications that are driven by IDL.
The IDL Export Bridges provide the ability to easily export an IDL object as a
native Java or ActiveX/COM object for use in external environments (such as Visual
C++ and Visual Basic). When exported, an IDL object will appear like a native
object in the target environment and, as such, doesn't require the user to know IDL
syntax or operating methodologies. The user interacts with the objects using native
methodologies and syntax. The bridge technology will convert data between the
native formats and IDL as well as dispatch the method calls being made to the target
IDL object. While the classic IDL execute string methodology is still available, for
non-IDL users this technology provides a rapid method to use and deploy
functionality developed in IDL.
The course that are currently offered for the IDL software package include :
• Introduction to IDL :
o Scientists and programmers starting to use IDL for exploring their data
become immediately more productive with this three-day course.
Beginning with the basic concepts of variables and line plotting, the
course takes students through file manipulation, programming
methods, interactive data visualization and analysis techniques. Users
are introduced to the IDL Development Environment (IDLDE) and IDL's
advanced mathematical and image processing capabilities. This class
is perfect for new users of IDL.
• Intermediate Programming with IDL :
o Standard techniques are presented for building IDL programs to
perform custom analyses that can be easily used by others. Topics
include advanced visualization techniques, use of built-in data analysis
and image processing routines, development of applications employing
a graphical user interface, introduction to object-oriented
programming, introduction to the IDL Object Graphics system and a
discussion of linking with external programs using the CALL_EXTERNAL
function.
• Advanced Topics in IDL :
o In this course a significant IDL application is planned, designed and
built. The application employs a user interface that allows interactive
manipulation of objects in a graphical scene. Emphasis is placed on
visualization using the newest features of the IDL Object Graphics
System and the IDL Widget Toolkit. This course is designed for the
scientist or programmer wanting to increase the visual impact and
usability of their IDL applications for customers or colleagues.
• iTools Programming :
o Learn how to work within the iTools Component Framework to build
your own iTool. Construct and register iTools visualizations, file
readers and writers, manipulators and operations. Learn how to
modify the default iTools user interface, construct your own iTools user
interface and embed an iTool in an existing IDL widget application.
This class includes a review of object-oriented programming in IDL,