Cube GUI User Guide  (CubeGUI 4.8.2, revision 7895e762)
Introduction in Cube GUI and its usage
Using the Display

This section explains how to use the CUBE-QT display component. After installation, the executable "cube" can be found in the specified directory of executables (specifiable by the ``prefix'' argument of configure, see the CUBE Installation Manual). The program supports as an optional command-line argument the name of a cube file that will be opened upon program start.

After a brief description of the basic principles, different components of the GUI will be described in detail.

Basic Principles

The CUBE-QT display has three tree browsers, each of them representing a dimension of the performance space (figure gui). Per default, the left tree displays the metric dimension, the middle tree displays the program dimension, and the right tree displays the system dimension. The nodes in the metric tree represent metrics. The nodes in the program dimension can have different semantics depending on the particular view that has been selected. In Figuregui, they represent call paths forming a call-tree. The nodes in the system dimension represent machines, nodes, processes, or threads from top to bottom.

cube1.png
"gui": CUBE display window
cube2.png
"gui2": CUBE display window with expanded metric node ''Execution''

Each node is associated with a value, which is called the severity and is displayed simultaneously using a numerical value as well as a colored square. Colors enable the easy identification of nodes of interest even in a large tree, whereas the numerical values enable the precise comparison of individual values. The sign of a value is visually distinguished by the relief of the colored square. A raised relief indicates a positive sign, a sunken relief indicates a negative sign.

Users can perform two basic types of actions: selecting a node or expanding/collapsing a node. In the metric-tree in figure gui, the metric Execution is selected. Selecting a node in a tree causes the other trees on its right to display values for that selection. For the example of figure gui, the metric-tree displays the total metric values over all call-tree and system nodes, the call-tree displays values for the Execution metric over all system entities, and the system-tree for the Execution metric and the adi call-tree node. Briefly, a tree is always an aggregation over all selected nodes of its neighboring trees to the left.

Collapsed nodes with a subtree that is not shown are marked by a [+] sign, expanded nodes with a visible subtree by a [-] sign. You can expand/collapse a node by left-clicking on the corresponding [+]/[-] signs. Collapsed nodes have inclusive values, i.e., their severity is the sum of the severities over the whole collapsed subtree. For the example of Figuregui, the Execution metric value $ 3496.10 $ is the total time for all executions. On the other hand, the displayed values of expanded nodes are their exclusive values. E.g., the expanded Execution metric node in Figure gui2 shows that the program needed $ 2839.54 $ seconds for execution other than MPI.

Note that expanding/collapsing a selected node causes the change of the current values in the trees on its right-hand side. As explained above, in our example in Figure gui the call-tree displays values for the Execution metric over all system entities. Since the Execution node is collapsed, the call-tree severities are computed for the whole Execution metric's subtree. When expanding the selected Execution node, as shown in Figure gui2, the call-tree displays values for the Execution metric without the MPI metric.

GUI Components

The GUI  consists (from top to bottom) of


Subsections:

The three resizable panes offer different views: the metric, the call, and the system pane. You can switch between the different tabs of a pane by left-clicking on the desired tab at the top of the pane. Note that the order of the panes can be changed (see the description of the menu item Display => Dimension order in Section Menu Bar ).

The metric pane provides only the metric-tree browser. The call pane offers a call-tree browser and a flat call profile. If OpenMP tasks have been instrumented, an additional task-tree is inserted. The system pane has a system-tree browser. Tree browsers also provide a context menu.

Menu Bar

The menu bar consists of four menus: a file menu, a display menu, a plugin menu and a help menu. Some menu functions also have a keyboard shortcut, which is written besides the menu item's name in the menu. E.g., you can open a file with Ctrl+O without going into the menu. A short description of the menu items is visible in the status bar if you stay for a short while with the mouse above a menu item.

  1. File: The file menu offers the following functions:

    1. Open (Ctrl+O): Offers a selection dialog to open a CUBE file. In case of an already opened file, it will be closed before a new file gets opened. If a file got opened successfully, it gets added to the top of the recent files list (see below). If it was already in the list, it is moved to the top.

    2. Open URL: Opens a remote file dialog (see section Client-Server)

    3. Save as (Ctrl+S): Offers a selection dialog to save a copy of a CUBE file. Opened CUBE file stays loaded in cube.

    4. Close (Ctrl+W): Closes the currently opened CUBE file. Disabled if no file is opened.

    5. Open external: Opens a file for the external percentage value mode (see section Value modes).

    6. Close external: Closes the current external file and removes all corresponding data. Disabled if no external file is opened.

    7. Settings: Offers saving, loading, and deletion of global settings. Global settings don't depend on the loaded cube file and are saved in a system specific format. These settings e.g. store the appearance of the application like the widget sizes, color and precision settings, the order of panes, etc.

      "Restore last state" depends on a loaded cube file. If it is activated, the state of the cube file, e.g. selected and expanded items, is saved before the cube file is closed and restored after loading.

    8. Screenshot: The function offers you to save a screen snapshot in a PNG file. Unfortunately the outer frame of the main window is not saved, only the application itself.

    9. Quit (Ctrl+Q): Closes the application.

    10. Recent files: The last $ 5 $ opened files are offered for re-opening, the top-most being the most recently opened one. A full path to the file is visible in the status bar if you move the mouse above one of the recent file items in the menu.

  2. Display: The display menu offers the following functions:

    1. Dimension order: As explained above, CUBE has three resizable panes. Initially the metric pane is on the left, the call pane is in the middle, and the system pane is on the right-hand side. However, sometimes you may be interested in other orders, and that is what this menu item is about. It offers all possible pane orderings. For example, assume you would like to see the metric and call values for a certain thread. In this case, you could place the system pane on the left, the metric pane in the middle, and the call pane on the right, as shown in Figure order. Note that in panes to the left of the metric pane no meaningful valuescan be presented, since they miss a reference metric; in this case values are specified to be undefined, denoted by a ``-'' (minus) sign.

      cube3.png
      "order": Modified pane order via the menu ''Display => Dimension order''
      cube4.png
      "coloring": Configuration dialog of the default colormap which opened via the menu ''Display => Edit colormap''

    2. Choose/Edit colormap: Allows for selection of color maps and changing of color settings in a new dialog. In the configuration dialog, the Ok button applies the settings to the display and closes the dialog, the Apply button applies the settings to the display, and Cancel cancels all changes since the dialog was opened (even if "Apply" was pressed in between) and closes the dialog.

      The configuration dialog in Figure coloring shows the default color map for Cube. Other colormaps may be added using plugins, see for example the Advanced Colormap Plugin (Advanced Color Map Plugin). At the top of the dialog you see a color legend with some vertical black lines, showing the position of the color scale start, the colors cyan, green, and yellow, and the color scale end. These lines can be dragged with the left mouse button, or their position can also be changed by typing in some values between $ 0.0 $ (left end) and $ 1.0 $ (right end) below the color legend in the corresponding spins.

      The different coloring methods offer different functions to interpolate the colors at positions between the $ 5 $ data points specified above.

      With the upper spin below the coloring methods you can define a threshold percentage value between $ 0.0 $ and $ 100.0 $, below which colors are lightened. The nearer to the left end of the color scale, the stronger the lightening (with linear increase).

      With the spin at the bottom of the dialog you can define a threshold percentage value between $ 0.0 $ and $ 100.0 $ , below which values should be colored white.

      tau-value-view.png
      "tau-value-view": Value view config dialog for tau metrics

    3. Set font size: Opens a dialog to set the font size. The size can also be changed with Control+<mouse-wheel> or Control+<->/<+>

    4. Customize style sheets Opens a dialog to define Customization with Qt Stylesheets to change e.g. the fonts and sizes of GUI elements.

    5. Configure value view: This menu item opens a dialog in which the icon and the textual value representation of the tree items can be configured. Depending on the data type of the selected metric, additional options and additional value view plugins may be available. For metrics that consist of more than one value, e.g. tau metrics (see figure tau-value-view), the user can select which value should be used for the icon and which values for the following text.

    6. Precision: Activating this menu item opens a dialog for precision settings (see Figure precision). Besides Ok and Cancel, the dialog offers an Apply button, that applies the current dialog settings to the display. Pressing Cancel undoes all changes due to the dialog, even if you already pressed Apply previously, and closes the dialog. Ok applies the settings and closes the dialog.

      It consists of two parts: precision settings for the tree displays, and precision settings for the selected value info widgets and the topology displays. For both formats, three values can be defined:

      1. Number of digits after the decimal point: As the name suggests, you can specify the precision for the fraction part of the values. E.g., the number 1.234 is displayed as 1.2 if you set this precision to 1, as 1.234 if you set it to 3, and as 1.2340 if you set it to 4.
      2. Exponent representation above $ 10^x $ with x: Here you can define above which threshold scientific notation should be used. E.g., the value 1000 is displayed as 1000 if this value is larger then 3 and as $ 1e3 $ otherwise.
      3. Display zero values below $ 10^{-x} $ with x: Due to inexact floating point representation, it often happens that users wish to round down values very near by zero to zero. Here you can define the threshold below which this rounding should take place. E.g., the value 0.0001 is displayed as 0.0001 if this value is larger than 3 and as zero otherwise.
      4. Use human readable units for bytes and occ: If enabled, units will be displayed in a human readable format, e.g. MB or GB.
      cube5.png
      "precision": Display => Precision

    7. Trees: This menu offers options to change the contents and the appearance of the items of all trees.

      1. Configure Tree Item Marker In this dialog, you can change the appearance of defined tree item markers. You may choose if the items should be marked with a special background color or with an icon (see Tree Item Marker).

      2. Demangle Function Names (only call trees) If this option is enabled (default), cube tries to demangle function names.

      3. Shorten Function Names (only call trees) This menu item opens a dialog in which you can hide parts of long function names. You may hide argument lists and return values of C++ functions. You may also hide namespaces, class and templates from C++ function names. For Fortran subroutines, module names can be hidden.

      4. Append rank to system tree items If this option is enabled, the MPI rank is appended to all system tree leafs. This is useful, if the MPI level is hidden or if there is a large amount of threads.

    8. Optimize width: Under this menu item CUBE offers widget rescaling such that the amount of information shown is maximized, i.e., CUBE optimally distributes the available space between its components. You can chose if you would like to stick to the current main window size, or if you allow to resize it.
    9. Show synchronization toolbar The synchronization of several cube instances is described in Synchronization of several cube instances.
    10. Show bookmark toolbar Shows a toolbar which allows you to save the current state of a loaded cube file along with a name and a textual description. The state implies e.g. the currenly selected items, the value mode of the trees, the active tabs and the state of the plugins. These states are saved next to the opened cube file in cubebasename.ini.
    11. Enable presentation mode If the presentation mode is enable, a mouse icon is shown next to the cursor
    12. Enable QWebEngine QWebEngine is used for the HTML-rendering of the documentation, if the module is available. On some systems, problems with the graphics driver or OpenGL cause QWebEngine to display a blank window. For that reason it's possible to disable QWebEngine (Display => QWebEngine) and to show the documentation in a basic layout instead. This option is also saved as setting and used for the next start of CubeGUI.

  3. Plugins: The plugin menu allows the user to define which plugins are laoded. For each loaded plugin, a submenu is added. The submenu contains a menu item to enable or disable the plugin and the plugin may add additional menu items.

    1. Initial activation settings: Opens a dialog to define which plugins should be loaded.
    2. Activate/deactivate plugins: Allows to activate or deactive a plugin for the current session.

  4. Help: The help menu provides help on usage and gives some information about CUBE.
    1. Getting started: Opens a dialog with some basic information on the usage of CUBE.

    2. Mouse and keyboard control: Lists mouse and keyboard controls as given in Section Source Code Viewer Keyboard control.

    3. What's this?: Here you can get more specific information on parts of the CUBE GUI. If you activate this menu item, you switch to the ``What's this?'' mode. If you now click on a widget, an appropriate help text is shown. The mode is left when help is given or when you press Esc.

      Another way to ask the question is to move the focus to the relevant widget and press Shift+F1.

    4. About: Opens a dialog with release information.

    5. Plugin info Shows information about the plugin version, a short description and its location in the file system
    6. Plugin documentation shows the plugin documentation in a browser window

    7. Selected metric description: Opens a new window showing the description of the currently selected metric, equivalent to Documentation in the metric-tree context menu. Disabled if online documentation is unavailable.

    8. Selected region description: Opens a new window showing the description of the currently selected region, equivalent to Documentation in the call-tree context menu. Disabled if online documentation is unavailable.

Value modes

Each tree view has its own value mode combobox, a drop-down menu above the tree, where it is possible to change the way the severity values are displayed.

The default value mode is the Absolute value mode. In this mode, as explained below, the severity values from the CUBE file are displayed. However, sometimes these values may be hard to interpret, and in such cases other value modes can be applied. Basically, there are three categories of additional value modes.

Depending on the type and position of the tree, the following value modes may be available:

  1. Absolute (default): Available for all trees. The displayed values are the severity value as read from the cube file, in units of measurement (e.g., seconds). Note that these values can be negative, too, i.e., the expression ``absolute'' in not used in its mathematical sense here.
  2. Own root percent:Available for all trees. The displayed node values are the percentage of their absolute values with respect to the absolute value of their root node in collapsed state.
  3. Metric root percent: Available for trees on the right-hand side of the metric-tree. The displayed node values are the percentage of their absolute values with respect to the absolute value of the collapsed metric root node. If there are several metric roots, the root of the selected metric node is taken. Note, that multiple selection in the metric-tree is possible within one root's subtree only, thus there is always a unique metric root for this mode.
  4. Metric selection percent: Available for trees on the right-hand side of the metric-tree. The displayed node values are the percentage of their absolute values with respect to the selected metric node's absolute value in its current collapsed/expanded state. In case of multiple selection, the sum of the selected metrics' values for the percentage computation is taken.
  5. Call root percent: Available for trees on the right-hand side of the call-tree. Similar to the metric root percent, but the call-tree root instead of the metric-tree root is considered. In case of multiple selection with different call roots, the sum of those root values is considered.
  6. Call selection percent: Available for trees on the right-hand side of the call-tree. Similar to the metric selection percent, percentage is computed with respect to the selected call node's value in its current collapsed/expanded state. In case of multiple selections, the sum of the selected call values is considered.
  7. System root percent: Available for trees on the right-hand side of the system-tree. Similar to the call root percent, the sum of the inclusive values of all roots of selected system nodes are considered for percentage computation.
  8. System selection percent:Available for trees on the right-hand side of the system-tree. Similar to the call selection percent, percentage is computed with respect to the selected system node(s) in its current collapsed/expanded state.
  9. Peer percent:For the system-tree only. The peer percentage mode shows the percentage of the nodes' inclusive absolute values relative to the largest inclusive absolute peer value, i.e., to the largest inclusive value between all entities on the current hierarchy depth. For example, if there are 3 threads with inclusive absolute values 100, 120, and 200, then they have the peer percent values 50, 60, and 100.
  10. Peer distribution:For the system-tree only. The peer distribution mode shows the percentage of the system nodes' inclusive absolute values on the scale between the minimum and the maximum of peer inclusive absolute values. For example, if there are 3 threads with absolute values 100, 120 and 200, then they have the peer distribution values 0, 20 and 100.
  11. External percent: Available for all trees, if the metric tree is the left-most widget. To facilitate the comparison of different experiments, users can choose the external percentage mode to display percentages relative to another data set. The external percentage mode is basically like the metric root percentage mode except that the value equal to 100% is determined by another data set.

Note that in all modes, only the leaf nodes in the system hierarchy (i.e., processes or threads) have associated severity values. All other hierarchy levels (i.e., machines, nodes and eventually processes) are only used to structure the hierarchy. This means that their severity is undefined—denoted by a ``-'' (minus) sign—when they are expanded.

System resource subsets

By default, all system resources (typically threads) are included when determining boxplot statistics. Other defined subsets can be chosen from the combobox below the boxplot, such as ``Visited'' threads which are only those threads that visited the currently selected callpath. The current subset is retained until another is explicitly chosen or a new subset is defined.

Additional subsets are defined from the system-tree with the Define subset context menu using the currently selected threads via multiple selection (Ctrl+<left-mouse click>) or with the Find Items context menu selection option.

Tree browsers

A tree browser displays different hierarchical data structures in form of trees. Currently supported tree types are metric-trees, call-trees and their flat call profiles, and system-trees. The structure of the displayed data is common in all trees: The indentation of the tree nodes reflects the hierarchical structure. Expandable nodes, i.e., nodes with non-hidden children, are equipped with a [+]/[-] sign ([+] for collapsed and [-] for expanded nodes). Furthermore, all nodes have a color icon, a value, and a label.

The value of a node is computed, as explained earlier, basing on the current selections in the trees on the left-hand side and on the current value mode. The precision of the value display in trees can be modified, see the menu item Display => Precision in Section Menu Bar. The color icon reflects the position of the node's value between $ 0.0 $ and a maximal value. These maximal value is the maximal value in the tree for the absolute value mode, or $ 100.0 $ otherwise. See the menu item Display => Choose colormap in Section Menu Bar and the context menu item Min/max values in the context menu description below for color settings.

A label in the metric-tree shows the metric's name. A label in the call-tree shows the last callee of a particular call path. If you want to know the complete call path, you must read all labels from the root down to the particular node you are interested in. After switching to the flat profile view (see below), labels in the flat call profile denote methods or program regions. A label in the system-tree shows the name of the system resource it represents, such as a node name or a machine name. Processes and threads are usually identified by a rank number, but it is possible to give them specific names when creating a CUBE file. The thread level of single-threaded applications is hidden. Multiple root nodes are supported.

After opening a data set, the middle panel shows the call-tree of the program. However, a user might wish to know which fraction of a metric can be attributed to a particular region (e.g., method) regardless of from where it was called. In this case, you can switch from the call-tree view (default) to the flat-profile view (Figure region). In the flat-profile view, the call-tree hierarchy is replaced with a source-code hierarchy consisting of two levels: regions and their subroutines. Any subroutines are displayed as a single child node labeled Subroutines. A subroutine node represents all regions directly called from the region above. In this way, you are able to see which fraction of a metric is associated with a region exclusively, that is, without its regions called from there.

When tasks are encountered while reading the Cube file, a third tab next to call-tree is provided to display them separately. In general terms, tasks are pieces of code scheduled and executed by a runtime asynchronously. Due to their asynchronous nature and their ability to be suspended and continued at a potentially different position in the call-tree handling them inside the call-tree itself may lead to inconsistent results. For OpenMP, the call-tree therefore contains only stub nodes with visit and time metric values at those execution points, while the executions and their task local call-trees will be displayed in a separate tasks tab. Currently, only OpenMP tasks are generated by Score-P, however the paradigm attribute of those task instances allows handling of tasks of different paradigms.

If tasks are involved, the values of the trees on the left (default: metric tree) depend on the active call tab. The task-tree only contains the task related paths. The call-tree contains all paths except for the task-local trees, which are replaced by stub nodes at their execution points. The flat-tree on the other hand, still contains all execution paths. There may be items of the flat-tree, that cannot be calculated for exclusive metrics. These items consist of paths from the task tree and of paths from the call-tree. Their exact contributions cannot be determined. These values are marked with a dash and a warning message is displayed on the status line.

Tree displays are controlled by the left and right mouse buttons and some keyboard keys. The left mouse button is used to select or expand/collapse a node: You can expand/collapse a node by left-clicking on the attached [+]/[-] sign, and select it by left-clicking elsewhere in the node's line. To select multiple items, Ctrl+<left-mouse click> can be used. Selection without the Ctrl key deselects all previously selected nodes and selects the clicked node. In single-selection mode you can also use the up/down arrows to move the selection one node up/down. The right mouse button is used to pop up a context menu with node-specific information, such as online documentation (see the description of the context menu below).

cube7.png
"region": CUBE flat profile

Each tree has its own context menu which can be activated by a right mouse click within the tree's window. If you right-click on one of the tree's nodes, this node gets framed, and serves as a reference node for some of the menu items. If you click outside of tree items, there is no refernce node, and some menu items are disabled.

The context menu consists, depending on the type of the tree, of some of the following items. If you move the mouse over a context menu item, the status bar displays some explanation of the functionality of that item.

  1. Collapse all: Collapses all nodes in the tree.

  2. Collapse subtree: Enabled only if there is a reference node. It collapses all nodes in the subtree of the reference node (including the reference node).

  3. Expand all: Expands all nodes in the tree.
  4. Expand subtree: Enabled only if there is a reference node. Expands all nodes in the subtree of the reference node (including the reference node).
  5. Expand largest: Enabled only if there is a reference node. Starting at the reference node, expands its child with the largest inclusive value, and continues recursively with that child until it finds a leaf.
  6. Expand marked: Shows all marked nodes by expanding their parents (see Tree Item Marker).
  7. Expand current level: For system-trees only. Shows all nodes that are on the same hierarchy level as the chosen one by expanding their parents.

  8. Dynamic hiding: Not available for metric-trees. This menu item activates dynamic hiding. All currently hidden nodes get shown. You are asked to define a percentage threshold between $ 0.0 $ and $ 100.0 $. All nodes whose color position on the color scale (in percent) is below this threshold get hidden. As default value, the color percentage position of the reference node is suggested, if you right-clicked over a node. If not, the default value is the last threshold. The hiding is called dynamic, because upon value changes (caused for example by changing the node selection) hiding is re-computed for the new values. In other words, value changes may change the visibility of the nodes.

    1. Redefine threshold: This menu item is enabled if dynamic hiding is already activated. This function allows to re-define the dynamic hiding threshold as described above.

    During dynamic hiding, for expanded nodes with some hidden children and for nodes with all of its children hidden, their displayed (exclusive) value includes the hidden children's inclusive value. The percentage of the hidden children is shown in brackets next to this aggregate value.

  9. Static hiding: Not available for metric-trees. This menu item activates static hiding. All currently hidden nodes stay hidden. Additionally, you can hide and show nodes using the now enabled sub-items:

    1. Static hiding of minor values: Enabled only in the static hiding mode. As described under dynamic hiding, you are asked for a hiding threshold. All nodes whose current color position on the color scale is below this percentage threshold get hidden. However, in contrast to dynamic hiding, these hidings are static: Even if after some value changes the color position of a hidden node gets above the threshold, the node stays hidden.
    2. Hide this: Enabled only in the static hiding mode if there is a reference node. Hides the reference node.
    3. Show children of this: Enabled only in the static hiding mode if there is a reference node. Shows all hidden children of the reference node, if any.

    Like for dynamic hiding, for expanded nodes with some hidden children and for nodes with all of its children hidden, their displayed (exclusive) value includes the hidden children's inclusive value. The percentage of the hidden children is shown in brackets next to this aggregate value.

  10. No hiding: Not available for metric-trees. This menu item deactivates any hiding, and shows all hidden nodes.

  11. Find items: For all trees. Opens a text input widget below the corresponding tree to enter a regular expression to search for. If the user called the context menu over an item, the default text is the name of the reference node. All non-hidden nodes whose names contain the given expression are marked with a yellow background, and all collapsed nodes whose subtree contains such a non-hidden node by a light yellow background.

    The button expand all expands all found items.

    The button select all selects all found items. The selected items may still be collapsed.

    The arrow buttons select the next or the previous found item. The shortcuts for these actions are F3 and Shift+F3.

  12. Clear found items: For all trees. Removes the background markings of the preceding "find items" action.

  13. Define subset: Only for system-tree. Uses the currently selected system resources (e.g., from a preceding Find items) to create a new subset of all system resources (typically threads) with the provided name. This is added to the combobox at the bottom of the system-tree and boxplot statistics panes, and becomes the currently active subset for which statistics are calculated.

  14. Info/Documentation: For metric and call-trees Shows combined information about the selected metric an call-tree items in a new tab. For the selected metric, information about display, unique name, data type, unit of measurements and kind of metric is shown. If the metric is derived, the CubePL expression is shown.

    For the selected call path, information about call path id (to use it with command line tools like cube_dump), region begining line, region ending line, region module, url with the online help and finally description of the region is shown.

    If online documentation for the reference node is available, it is shown in a html widget below the informataion panels. For example, metrics might point to an online documentation explaining their semantics, or regions representing library functions might point to the corresponding library documentation.

    QWebEngine is used for the HTML-rendering of the documentation, if the module is available. On some systems, problems with the graphics driver or OpenGL cause QWebEngine to display a blank window. For that reason it's possible to disable QWebEngine (Display => QWebEngine) and to show the documentation in a basic layout instead. This option is also saved as setting and used for the next start of CubeGUI.

    Disabled, if not clicked over metric or call path item.

    loop.png
    "looplabel": The item main_loop with 1000 iteration is marked as a loop. The aggregated view on the right is the result of selecting ''Hide iterations''.

  15. Hide iterations: Only visible for calltree items that are recognized or manually defined as loop (see "Set as loop" below). By activating, all children of the loop are hidden. The grandchildren are shown and its values for the different iterations are aggregated (see Figurelooplabel).

  16. Call site: For call-trees only. Enabled only if there is a reference node. Offers information about the caller of the reference node.

    1. Location: Displays information about the module and position within the module (line numbers) of the caller of the reference node.
    2. Set as loop: Marks the selected tree item as loop. All subitems are treated as iterations. An additional context menu item "Hide iterations" appears.

  17. Called region: For call-trees only. Enabled only if there is a reference node. Offers information about the reference node.

    1. Info: Gives some short information about the reference node.
    2. Documentation: Shows some (usually more extensive) online description for the reference node. Disabled if no online documentation is available.
    3. Location: Displays information about the module and position within the module (line numbers) where the callee method of the reference node is defined.

  18. Min/max values: Not for metric-trees. Here you can activate and deactivate the application of user-defined minimal and maximal values for the color extremes, i.e., the values corresponding to the left and right end of the color legend. If you activate user-defined values for the color extremes, you are asked to define two values that should correspond to the minimal and to the maximal colors. All values outside of this interval will get the color gray. Note that canceling any of the input windows causes no changes in the coloring method. If user-defined min/max values are activated, the selected value information widget (see Section Selected value info) displays a (u)'' foruser-defined'' behind the minimal and maximal color values.

  19. Statistics: Only available if a statistics file for the current CUBE file is provided. Displays statistical information about the instances of the selected metric in the form of a box plot. For an in-depth explanation of this feature see subsection Statistical information about performance patterns.

  20. Max severity in trace browser: Only available for metric and call-trees and only if a statistics file providing information about the most severe instance(s) of the selected metric is present. If CUBE is already connected to a trace browser (via File => Connect to trace browser), the timeline display of the trace browser is zoomed to the position of the occurrence of the most severe pattern so that the cause for the pattern can be examined further. For a more detailed explanation of this feature see subsection Display of most severe pattern instances using a trace browser.

  21. Cut call tree/Cut selected call tree items This context menu is enabled, if the right mouse button is pressed on a call tree item. If the mouse button is pressed and the item below the mouse pointer is part of a group of selected items, the action affects all selected items. Otherwise, only the item below the mouse item will be modified. The menu offers different modification possibilities:

    1. Set as root: Removes all call paths above the selected items and sets selected call paths as a root nodes.
    2. Prune element: Removes the selected items and all their children. Their inclusive value will be added then to the exclusive value of their parents.
    3. Set as leaf: Removes all children of the elements and shows the inclusive values.
    4. Undo Undo last operation.

  22. Sort by inclusive/exclusive value (descending): Sorts the nodes by their current values in descending order. The items will be automatically sorted, if the values change. If "Apply now" is selected, the values are only sorted once.
  23. Sort by name (ascending): Sorts the nodes alphabetically by name in ascending order.
  24. Sort by name and trailing number (ascending): For system tree only. Sorts the nodes alphabetically by name and the trailing rank in ascending order.
  25. Sort by order of definition: Restores the original order.

Selected value info

Below each pane there is a selected value information widget. If no data is loaded, the widget is empty. Otherwise, the widget displays more extensive and precise information about the selected values in the tree above. This information widget and the topologies may have different precision settings than the trees, such that there is the possibility to display more precise information here than in the trees (see Section Menu Bar, menu Display => Precision).

The widget has a 3-line display. The first line displays at most 4 numbers. The left-most number shows the smallest value in the tree (or $ 0.0 $ in any percentage value mode for trees, or the user-defined minimal value for coloring if activated), and the right-most number shows the largest value in the tree (or $ 100.0 $ in any percentage value mode in trees, or the user-defined maximal value for coloring if activated). Between these two numbers the current value of the selected node is displayed, if it is defined. Additionally, in the absolute value mode it is followed by the percentage of the selected value on the scale between the minimal and maximal values, shown in brackets. Note that the values of expanded non-leaf system nodes and of nodes of trees on the left-hand side of the metric-tree are not defined. If the value mode is not the absolute value mode, then in the second line similar information is displayed for the absolute values in a light gray color.

In case of multiple selection, the information refers to the sum of all selected values. In case of multiple selection in system trees in the peer distribution and in the peer percent modes, this sum does not state any valuable information, but is displayed for consistency reasons.

If the widget width is not large enough to display all numbers in the given precision, then a part of the number displays get cut down and a `` $ \ldots $ '' indicates that not all digits could be displayed.

Below these numbers, in the third line, a small color bar shows the position of the color of the selected node in the color legend. In case of undefined values, the legend is filled with a gray grid.

Color legend

By default, the colors are taken from a spectrum ranging from blue over cyan, green, and yellow to red, representing the whole range of possible values. You can change the color settings in the menu,Display => Choose colormap, see Section Menu Bar. Exact zero values are represented by the color white (in topologies you can decide whether you would like to use white or the minimal color, see Section System Topology Plugin, menu Topology).

Status Bar

The status bar displays some status information, like state of execution for longer procedures, hints for menus the mouse pointing at etc.

The status bar shows the most recent log message. By clicking on it, the complete log becomes visible.


Cube Writer Library    Copyright © 1998–2022 Forschungszentrum Jülich GmbH, Jülich Supercomputing Centre
Copyright © 2009–2015 German Research School for Simulation Sciences GmbH, Laboratory for Parallel Programming