ILNumerics - Technical Computing Tools

High Performance Framework for Visualization

and Computing in Industry and Science

 

Array Visualizer Quick Start

Everything you need to know about ILNumerics Array Visualizer:

Or read the in-depth manuals:

Visualizing Debug Data - 3 Simple Steps

ILNumerics Array Visualizer HowTo in three Steps

1. When halted in your Visual Studio debug session go to VIEW -> Other Windows -> Array Visualizer.

2. Enter any valid array expression in the textbox of the Array Visualizer Window.

3. Select the plotting output type from the list of available 2D and 3D plots.

The Array Visualizer handles arbitrary expressions yielding one of the following array types:

  • .NET (C#, Visual Basic): ILNumerics arrays (ILArray<T>, ILInArray<T>, ...)
  • .NET (C#, F#, Visual Basic): all System.Array, pointer types if applicable
  • .NET struct arrays, arrays of custom records / structs
  • C/C++: 1D arrays (double a[500], etc.)
  • C/C++: nested 1D arrays (multidimensional arrays, int b[50][40], ...)
  • C/C++: pointers of any numeric type (int*, float[5]*)
  • C/C++: instances of std::vector<T>, std::array<T,n>, std::valarray<T>
  • FORTRAN (ifort): all applicable array types, including ND arrays, ALLOCATABLE arrays and arrays of structs.
  • All common numeric element types are supported in any language.

The expression entered in the Array Visualizer will be evaluated as follows:

  • The context of the current debug stack frame is valid. Hence, your program must be halted in debug mode.
  • The Array Visualizer will use the same debug engine as used for the debugee. Any code which is valid in the current language can be used as expression for the Array Visualizer.You may use variables from the current scope. Or enter arbitrary valid custom expressions!
  • Expressions are of arbitrary complexity. They may include calls to any function reachable from your debug scope.

Examples:

In order to visualize the content of an array variable A just type 'A' and hit [Enter].

Ad-hoc visualizations of any vector data are possible by entering code which creates an array containing the desired elements. For C# one could write: new[] {1.2, 5, -2.223, 1, 1.02 } in order to create, let's say, a line plot based on these 5 values:

Read the manual specific to your language to learn everything about debug data plotting: C#, F#, Visual Basic, C/C++, FORTRAN.

Entering Expressions

There are two main modes for the Array Visualizer:

  • Use text expressions as simple language elements (array variables, function calls yielding arrays, etc.)
  • Prefix your text expressions with array descriptors to determine additional properties.

By default, no array descriptor expression is used. One simply enters or changes the array expression and receives the current result. All array properties are automatically derived from the expression.

In case not all array properties can be automatically determined from the expression or if the user decides to take more control of the target array, the Array Visualizer is switched to the second mode and the array descriptor is prepended to the language expression. Read more about array descriptors.

Reseting Array Descriptor Data

In array descriptor mode, the data provided by the array descriptor isprioritized over any real array properties. This allows to reinterpret array data in arbitrary ways. In order to clear the array descriptor and start all over with the actual array properties, simply clear the whole expression window and start typing from scratch. Alternatively, hold down the CTRL key together with the ENTER key when committing an expression for evaluation. This will clear any predefined array descriptor but keep the array expression untouched.

Making Use of Expression Logs

Expressions entered into the Array Visualizer are stored for later retrieval. This is well known from other places in Visual Studio and helps to come back to an earlier expression easily and quickly. The history will be shown directly below the expression text box when the user begins to enter an expression. The list of expressions is filtered by the start of the current expression text box content.

In order to enable the list of historic expression manually, press the DOWN cursor key when the focus is in the expression textbox.

Navigating the history list

  • Cursor keys up / down: select the next / previous list item.
  • Curson key right / Enter / Tab: accept the currently highlighted item for re-evaluation.
  • ESC key: hide the history list without changing the current expression.

Exporting Debug Data

The Array Visualizer lets you export the data currently shown to a large number of data formats and images. The Share menu on the top right of the Array Visualizer tool window provides access to all functions. Export your data as PNG, SVG, bitmap, CSV, HDF5 or Matlab files! Or simply copy and paste the data into Microsoft Excel tables, Microsoft Word as exact numbers or image objects.

Read more ...

Error Handling

Errors happen. If you entered an expression which cannot be evaluated, if there is user input missing, if anything else goes wrong - the Array Visualizer will let you know. The error is shown directly beneath the expression text as an info bubble:

The bubble is shown for a couple of seconds. In order to inspect the error more closely, visit the Output window. All errors are also logged in the General tab.

Compatibility

The Array Visualizer is available for all recent Visual Studio® versions starting with Visual Studio 2010, including Visual Studio Community Edition. It supports C#, F#, Visual Basic, C/C++, and FORTRAN (ifort) on 32 and 64 bit projects. Download and install your trial today!

Licensing

A free license for the Array Visualizer is included in each license of the Computing Engine and/or Visualization Engine. A stand alone license for the Array Visualizer can be obtained. More details

Limitations in the Trial Version

There is no limitation during the trial time period of 14 days! After the trial ended the maximum lengths of data dimensions is limited to 10 elements and a valid license must be purchased to remove this restriction: sales@ilnumerics.net

 

Further reading: