Using the Profiler Utility

The Natural Profiler is used to monitor the internal process flow of a Natural application and to analyze the performance and the code coverage of the application. Profiling of Natural applications is activated by switching on the ACTIVE subparameter of the PROFILER profile parameter. The Natural Profiler writes the collected Profiler event data to a Profiler resource file. See PROFILER – Profile a Natural Session in the Parameter Reference documentation.

Code coverage of Natural applications is activated by switching on the ACTIVE subparameter of the COVERAGE profile parameter (see the Parameter Reference documentation). Natural code coverage writes the collected coverage data to a code coverage resource file.

The Profiler utility runs in batch mode only. It provides functions to control the Profiler and code coverage data collection and to process the resulting data.

  1. With the Profiler data collection functions, the data collection can be paused and restarted (see also Starting and Pausing Data Collection).

  2. The data processing functions read and process the event data from the Profiler resource file. Unconsolidated event data can be consolidated.

    You can output statistics, a program summary, a line summary and a transaction summary, a program trace, an event trace with the most important data, and reports on program and statement coverage. You can export the resulting data in text or CSV (comma-separated values) format.

The Profiler resource file can be read by NaturalONE which displays the full event trace and provides a performance analysis (hot spots) of the Natural batch application. Coverage data can be inspected in the NaturalONE Coverage view and in the NaturalONE source editor. The exported profiling event data can be analyzed with the Natural Profiler MashApp which visualizes the data on an interactive MashZone dashboard.

This section covers the following topics:


Quick Start for Profiling

This section briefly describes the steps required for profiling Natural applications and viewing the results. The instructions provided here may serve as a guideline when starting to use the Natural Profiler. Detailed information regarding the steps is provided in the remainder of this chapter.

The steps to take depend on the evaluation you want to perform for your application as illustrated in the following graphic:

graphics/profiler_quick_start_winux.png

  1. Check that the prerequisites are met.

  2. Activate the profiling of the Natural session by switching on the ACTIVE subparameter of the PROFILER profile parameter in the NATPARM parameter file or dynamically when invoking Natural. Example for dynamic parameter specification:

    PROFILER=(ACTIVE=ON,RESNAME=ResName,RESLIB=RESLIB)

    In the example above, the Profiler event data is written to a resource file with the name ResNam.nprf in the library RESLIB. See PROFILER – Profile a Natural Session in the Parameter Reference documentation.

  3. Open the NPRF resource in NaturalONE to view the hot spots and the event trace.

  4. Submit a Natural batch job with the Profiler utility READ function to print an event trace, a program trace and the Profiler statistics. Example:

    FUNCTION=READ           /* Read Profiler data
      RESOURCE-LIB=RESLIB   /* Resource library
      RESOURCE-TYPE=NPRF    /* Use resource type NPRF
      EVENT=ON              /* Print event trace
      PROGRAM=ON            /* Print program trace
      STATISTICS=ON         /* Print statistics

    See also Profiler Utility READ Function. This section also describes how to generate a transaction summary.

  5. Submit a Natural batch job with the Profiler utility CONSOLIDATE function to consolidate (aggregate) the event data. Example:

    FUNCTION=CONSOLIDATE    /* Consolidate Profiler data
      RESOURCE-LIB=RESLIB   /* Resource library
      REPLACE=YES           /* Replace resource

    The consolidated Profiler event data is written to the resource ResNam.nprc in the library RESLIB. See Consolidating Event Data.

  6. Open the NPRC resource in NaturalONE to view the hot spots.

  7. Submit a Natural batch job with the Profiler utility READ function to generate a program summary, a line summary and the Profiler statistics. Example:

    FUNCTION=READ           /* Read Profiler Data
      RESOURCE-LIB=RESLIB   /* Resource library
      RESOURCE-TYPE=NPRC    /* Use resource type NPRC
      PROGRAM=ON            /* Print program summary
      LINE=ON               /* Print line summary
      STATISTICS=ON         /* Print statistics

    See also Profiler Utility READ Function. This section also describes how to generate a transaction summary.

  8. Submit a Natural batch job with the Profiler utility MASHZONE function to write the data to Work File 7 in the format expected by the Natural Profiler MashApp. Use as Work File 7 a CSV (comma-separated values) file in the Natural Profiler data directory in the MashZone environment. Example:

    FUNCTION=MASHZONE       /* Write MashZone format to Work File 7
      RESOURCE-LIB=RESLIB   /* Resource library

    See also Exporting Event Data for MashZone.

  9. Enter a reference to the new file in the Overview.csv file in the resources\Profiler directory.

    Open the Natural Profiler MashApp and select the corresponding input file to evaluate the event data.

Notes:

  1. If the resource name is not explicitly specified in the READ, CONSOLIDATE or MASHZONE function of the Profiler utility, the last created NPRF or NPRC resource in the library is used.
  2. If you plan to profile a long-running batch application, refer to the section Profiling Long-Running Applications. It covers strategies of how to minimize the number of events to be monitored.
  3. The NaturalONE Profiler is described in the NaturalONE documentation.

Quick Start for Code Coverage

This section briefly describes the steps required for performing the code coverage of a Natural batch applications and viewing the results. The instructions provided here may serve as a guideline when starting to use Natural code coverage. Detailed information regarding the steps is provided in the remainder of this chapter.

The steps to take depend on the evaluation you want to perform for your application as illustrated in the following graphic:

graphics/profiler_quick_start_code_coverage_luw.png

  1. Check that the prerequisites are met.

  2. Activate code coverage of the Natural session by switching on the ACTIVE subparameter of the COVERAGE profile parameter (see the Parameter Reference documentation) in the NATPARM parameter file or dynamically when invoking Natural. Example for dynamic parameter specification:

    COVERAGE=(ACTIVE=ON,RESNAME=ResName,RESLIB=RESLIB)

    In the example above, the coverage data is written to a resource file with the name ResNam.ncvf in the library RESLIB.

  3. Open the NCVF resource in NaturalONE to obtain the Code Coverage view.

  4. From the NaturalONE Code Coverage view, you can directly edit the source. The editor shows all lines containing covered statements with a green background.

  5. Submit a Natural batch job with the Profiler utility READ function to print the program and statement coverage.

    Example:

    FUNCTION=READ           /* Read Profiler data
      RESOURCE-LIB=RESLIB   /* Resource library  
      RESOURCE-TYPE=NCVF    /* Use resource type 
      EVENT=ON              /* Print statement coverage
      PROGRAM=ON            /* Print program coverage
      EXPORT=ON             /* write to work 7     
      FORMAT=C              /* Semicolon/Comma/Text

    If the EXPORT keyword of the Profiler utility READ function is switched on, the output is written to Work File 7. If FORMAT is specified as C or S, the result is written as comma-separated values (CSV) where a comma or a semicolon is used as a separator, respectively.

  6. Export the data of Work File 7 with any tool (such as FTP) as a CSV-formatted file to a Windows environment if you want to process it further in Microsoft Excel.

Notes:

  1. If the resource name is not explicitly specified in the READ function of the Profiler utility, the NCVF resource created last in the library is used.
  2. The NaturalONE Code Coverage view and editor are described in the NaturalONE documentation.

Prerequisites

The following prerequisite must be met before you can use the Profiler utility:

Natural Parameter Settings

The Profiler utility data processing functions (CONSOLIDATE, READ, MASHZONE and LIST) cannot be executed if profiling is active. Deactivate the profiling infrastructure with the following (default) parameter setting:

PROFILER=(ACTIVE=OFF)

For details regarding the PROFILER parameter, see PROFILER – Profile a Natural Session in the Parameter Reference documentation.

Activate Data Processing

If NaturalONE is installed at your site, you can activate the Profiler utility data processing functions (CONSOLIDATE, READ, MASHZONE and LIST) with the following steps:

  1. Start NaturalONE.

  2. In the Natural Server view, map to the environment where the Profiler resources reside.

  3. Add the program ACTIVATE contained in the system library SYSPRFLR to a new or existing project in NaturalONE.

  4. Profile the program ACTIVATE with the context menu function Profile As > Natural Application.

  5. Verify that the user-defined event data on the Event Trace page of the NaturalONE Profiler contains the activation success message.

When the program ACTIVATE is profiled, a NaturalONE Profiler key is generated and written to the Natural resource NaturalONEProfilerKey.nprk in the system library SYSPRFLR. Each Profiler data processing function reads this resource and checks the key. If the key is valid, the function is performed. A newly generated key is valid for one year. It can always be regenerated.

The Profiler data processing function starts issuing a warning 9 days before the key expires, and returns an error message if no key is found or if the key is not valid.

Notes:

  1. Natural statement events (NS) are only generated for profiling if the corresponding Natural object was compiled with the profile parameter GPGEN set to (PROFILER=ON).GPGEN is described in the Parameter Reference documentation.
  2. Code coverage of a Natural application can only be performed if the corresponding Natural objects were compiled with the profile parameter GPGEN set to (COVERAGE=ON).

Invoking and Terminating the Profiler Utility

This section provides instructions for invoking and terminating the Profiler utility in batch mode.

Start of instruction setTo invoke the Profiler utility

  • Enter the following system command into the primary command input data set CMSYNIN:

    PROFILER

    Note:
    After the PROFILER system command, the Profiler expects one or more lines with Profiler keyword entries.

Start of instruction setTo terminate the Profiler utility

  • Enter the following Profiler keyword into the primary command input data set CMSYNIN:

    END-PROFILER

    Or:

    END

    Or:

    .

Syntax and Keywords

The Profiler utility in batch mode reads the Profiler keywords that control the profiling from the primary command input data set CMSYNIN. The Profiler reads the input lines until it reaches the END-PROFILER keyword (or END or .).

This section covers the following topics:

Profiler Utility Syntax

The symbols used in the syntax diagrams shown in this section are explained in System Command Syntax in the System Commands documentation.

You enter a Profiler utility command using either of the following syntax formats:

keyword[=value][,keyword[=value]]...

Or:

keyword
[value]
...

Notes:

  1. If a value is associated with a keyword but no equal sign is found, the Profiler expects the value in a separate input line without any other keyword (second syntax format).
  2. The first syntax format expects input in delimiter mode (IM=D).
  3. The second syntax format can be used if the Profiler is to be executed with the Natural STACK profile parameter or if the data is entered in forms mode (IM=F).

The following rules apply:

  • Empty lines and lines starting with an asterisk (*) are ignored.

  • All characters in a line from /* to */ or to the end of the line are ignored.

  • Some keywords have no associated value.

  • Blanks can be added before or after the keyword or value.

  • Multiple keywords in a line are separated by commas (applies to the first syntax format only).

  • A value can be enclosed in apostrophes ('value').

  • A value must not contain a comma.

  • Keywords and values can be specified in upper or lower case.

  • The maximum input line length is 78 characters.

The Profiler utility can be executed multiple times in one Natural session. For example, it is first executed with the START function, and then, after the execution of a user program, it is executed with the PAUSE function.

Example

The following Natural batch example runs the Profiler utility READ function:

natural BATCHMODE CMSYNIN=cmd.txt CMOBJIN=data.txt CMPRINT=out.txt CMWRK07=wrk07.txt

The content of the batch input file cmd.txt which contains the PROFILER command is shown below:

PROFILER
FIN

The content of the input file data.txt which contains the input for the Profiler utility is shown below:

*********************************************************************
* Read Profiler NPRF Resource                                        
*********************************************************************
TRACE=3                  /* Set Profiler trace level
FUNCTION=READ            /* Read Profiler resource
  RESOURCE-NAME='Demo01' /* Resource name   
  RESOURCE-LIB=PRFDATA   /* Resource library
  RESOURCE-TYPE=NPRF     /* Resource type   
  EVENT=ON               /* List events     
  STATISTICS=ON          /* List properties and statistics
  PROGRAM=ON             /* Program trace           
  PRINT=ON               /* Write to standard output
  EXPORT=ON              /* Write to work file 7   
  FORMAT=TEXT            /* Use text format   
END-PROFILER             /* End profiler input

After execution, out.txt contains the Profiler utility output and the internal trace (TRACE=3). wrk07.txt contains the Profiler utility output in text format (FORMAT=TEXT).

The following Natural example demonstrates how the Profiler utility PAUSE function is to be executed with the Natural STACK profile parameter:

natural PROFILER=(ACTIVE=ON,RESNAME=ResName,RESLIB=RESLIB)
STACK=(
PROFILER FUNCTION:PAUSE:END-PROFILER;
LOGON PRFDEMO
)

After execution, profiling of the Natural session is activated but the data collection is paused. The data collection can be started later with the Profiler utility START function.

Profiler Utility Keywords

The main keywords used in the syntax of the Profiler utility in batch mode are described in the following table. Any additional (subordinate) keywords available for a main keyword are described in the sections referenced in the table. In general, a subordinate keyword value must follow the main keyword value, for example:

FUNCTION=READ
  PRINT=ON

A subordinate keyword specified before the first FUNCTION or FILTER keyword is treated as a subordinate keyword of the first FUNCTION or FILTER keyword.

The following main keywords are available:

Keyword Value Description
FUNCTION   Perform a Profiler utility function.
CONSOLIDATE Consolidate (aggregate) resource data. See Consolidating Event Data.
LIST List Profiler resources. See Listing Profiler Resource Files in Maintaining Profiler Resource Files.
MASHZONE Export resource data in MashZone format. See Exporting Event Data for MashZone.
PAUSE Pause the data collection. See Starting and Pausing Data Collection.
READ Read and evaluate resource data. See Evaluating Event Data.
START Start or restart the data collection. See Starting and Pausing Data Collection.
TRACE 0 - 10 Set the level of internal trace of the Profiler trace session. The internal trace contains information such as Profiler errors and is written to the standard output of the trace session (CMPRINT data set). See Internal Trace.

Default: 2 (warning)

HELP   A summarized description of the Profiler keywords is written to standard output.
INCLUDE object-name The name of the Natural text object that contains Profiler input data.

See also Including Profiler Input from Natural Text Objects.

INCLUDE-LIB library-name The name of the Natural library that contains the text object specified with the INCLUDE keyword.

If the Natural system variable *LIBRARY-ID is specified, the name of the current library is used.

The library name is used for all following INCLUDE keywords.

Default: If INCLUDE-LIB is not specified before an INCLUDE keyword, the Natural system library SYSPRFLR is used by default.

See also Including Profiler Input from Natural Text Objects.

END-PROFILER

or

END

or

.

  End of Profiler input. The keyword END-PROFILER, END or a period (.) indicates the end of the Profiler input.

Events and Data Collected

This section describes the events and data processed by the Profiler utility.

Events

During a Natural session, different types of events can occur (for example, a program start) where the Profiler collects data specific to the event in a trace record. Each event is associated with an event type, that is, a one or two letter code. Related event types are combined into an event group which is denoted by a one letter code.

The following events, event types and event groups are available:

Event Event Type Event Group When the Event Occurs
Session Initialization SI S When a Natural batch session is initialized. Because the Profiler monitor session starts after the trace session, this event cannot be monitored.
Session Termination ST S When a Natural batch session is terminated. The Profiler always monitors this event.
Program Load PL P When a program (Natural object) is loaded or when it is already located in the buffer pool.
Program Start PS P When a program (Natural object) is started.
Program Termination PT P When a program (Natural object) is terminated.
Program Resume PR P When a program (Natural object) resumes control after another Natural object has been executed or when control returns to level 0 (no program active).
Program Information PI P When a program (Natural object) is accessed for the first time. This event is only triggered at Natural code coverage.
Before Database Call DB D Before a database call is executed.
After Database Call DA D After a database call has been executed.
Before Terminal I/O IB I Before a terminal input/output is executed.
After Terminal I/O IA I After a terminal input/output has been executed.
Before External Program Call CB C Before an external program call (CALL statement) is executed.
After External Program Call CA C After an external program call (CALL statement) has been executed.
Runtime Error E E When a Natural runtime error has occurred.
Natural Statement NS N When a Natural statement is executed. For technical reasons, there is no one-to-one relationship between a Natural source code statement and the corresponding object code in the cataloged object. Therefore, multiple Natural statements can be merged into one NS event and conversely, one Natural statement can cover multiple NS events.
Inbound RPC Message RI R When the Natural RPC server layer receives the client request.
Start of RPC Request Execution RS R When the Natural RPC server layer calls the Natural server program.
Outbound RPC Message RO R When the Natural RPC server returns the result to the client.
RPC Wait for Client RW R When the Natural RPC server waits for the next message from the client.
User-Defined Event U U When a user-defined event was generated.
Monitor Pause MP M When the data collection is paused.

A pause event can be caused by an explicit pause request, at the start of a block filter or when the data pool is full. The duration of a pause is not considered for the application performance analysis.

With each collected event, a CPU and an event timestamp are recorded. In general, a timestamp is taken at the beginning of an event. The duration of an event therefore equals the time that elapses between the timestamp of the event and the timestamp of the event that follows.

Data Collected

This section describes the data collected by the Natural Profiler:

General Data

The following data elements are collected at every event:

  • Event counter

  • Event type

  • Event time in units of microseconds

  • Session CPU time in units of microseconds

  • Trace session ID

  • Natural Security user group ID

  • Natural user ID

  • Natural application name

  • Program library

  • Program name

  • Program level

  • Copycode library

  • Copycode name

  • Statement line number

  • Statement op-code

  • Coverage flag (for Natural code coverage)

Notes:

  1. The Natural Profiler for UNIX and Windows does not yet collect RPC-related events.
  2. Natural code coverage only collects NS and PI events.
  3. Natural code coverage does not collect time values.
  4. A PI event is collected for each object accessed and for all copycodes included in the object (recursively).
Event-Specific Data

The following data is only collected at the following events:

Event Data Elements
Session Initialization None
Session Termination

Termination return code
Natural termination message code NAT99nn
Name of back-end program
Monitor CPU time in units of microseconds

Program Load

Name of program to be loaded
Name of load library
Invocation type

Program Resume None
Program Start/Termination

Program type
Database ID of program library
File number of program library

Program Information

Program type
Number of statements in the program or copycode
First statement item
INCLUDE line number
Parent copycode ID

Database Call

Database type
Command code
Command ID
Database ID
File number
Response code (event type DA)
Error subcode (event type DA)
Adabas command time (event type DA)

Terminal I/O

Number of bytes sent
Number of bytes read
Total session storage allocated
Compressed session storage length

External Program Call

Name of program called
Calling mode such as dynamic or static mode
Program link location
Parameter type such as reference or value
Response code (event type CA)

Runtime Error

Natural system error message code
External abend code
Name of error handling program

Natural Statement Profiling: None

Natural code coverage: Statement item identifier (GP offset)

Start of RPC Request Execution

Environment (C = client, S = server)

Subprogram name
Adabas user ID (ETID)
Conversation status
Logon indicator (Y = logon performed)
Impersonation indicator of RPC request (Y = impersonation performed)

Outbound/Inbound RPC Message / RPC Wait for Client

Environment (C = client, S = server)
Transport protocol
RPC function
Type of client user ID
Length of message
RPC return code
External conversation ID
Client user ID
Server node (event types RO and RW)
Server name (event types RO and RW)

User-Defined Event

Subtype of the user-defined event
Up to 249 bytes of user-defined information

Monitor Pause Type of monitor pause

Possible values:

R Monitor pause requested. This value is also set when the session is initialized with the Pause option.
F Start of a block of filtered-out events. Block filters are: library, program, line, FNAT, event count, or time filter.
W Trace session waits because of a data pool full situation.

Starting and Pausing Data Collection

When a Natural session is profiled, all event data of the session is collected by default.

You can start and pause data collection with the following methods:

Using Profiler Utility Functions

The Profiler utility START and PAUSE functions are used to start and pause data collection. The following syntax applies:

FUNCTION=START [COUNT={0|count-number}]
FUNCTION=PAUSE

Syntax Description:

Keyword for START Value Description
COUNT count-number Set the event counter of the next monitored event to the specified value.

Valid values for count-number:

0 to 2147483647

The event counter remains unchanged if a value of zero (0) is specified.

Using Profiler Utility Programs

The following Natural programs in the system library SYSPRFLR are supplied to perform Profiler utility functions:

Program Description
PRFSTART Start the data collection.
PRFPAUSE Pause the data collection.
PRFSTATE Get the state of the data collection.
PRFFCT Execute a Profiler utility function: START, PAUSE or STATE.

Start of instruction setTo use Profiler utility programs

  • Logon to the library SYSPRFLR or copy the programs to the library SYSTEM, to the appropriate steplib library, or to the required library.

    If PRFFCT is used, the application programming interface USR8210N has to be copied as well (see the following section).

    If PRFFCT is used in a client/server environment, copy PRFFCT to the client library and USR8210N to the server library.

    Note:
    PRFFCT expects as input the value START, PAUSE or STATE to perform the corresponding function.

Start of instruction setTo start the data collection

  • Execute the following program:

    PRFSTART

    Or:

    PRFFCT
    START

Start of instruction setTo pause the data collection

  • Execute the following program:

    PRFPAUSE

    Or:

    PRFFCT
    PAUSE

Start of instruction setTo retrieve the current state of the data collection

  • Execute the following program:

    PRFSTATE

    Or:

    PRFFCT
    STATE

Using the Application Programming Interface

The data collection can be started and paused from the profiled Natural application by calling the application programming interface (API) USR8210N. The API can also be used to get the current state of the monitoring process. The API is delivered in the SYSEXT library. For more information, see SYSEXT Utility - Natural Application Programming Interfaces.

Start of instruction setTo use the API

  • Copy the subprogram USR8210N to the library SYSTEM, to the appropriate steplib library, or to the required library.

    Note:
    USR8210N expects as the first parameter the value START, PAUSE or STATE to perform the corresponding function. The parameter values can be specified in uppercase or lowercase. On return, P-RETURN contains the return code and P-MESSAGE the success or error message.

Start of instruction setTo start the data collection

  • Use the interface with the CALLNAT statement:

    CALLNAT 'USR8210N' 'START' P-RETURN P-MESSAGE /* Start Profiler

Start of instruction setTo pause the data collection

  • Use the interface with the CALLNAT statement:

    CALLNAT 'USR8210N' 'PAUSE' P-RETURN P-MESSAGE /* Pause Profiler

Start of instruction setTo retrieve the current state of the data collection

  • Use the interface with the CALLNAT statement:

    CALLNAT 'USR8210N' 'STATE' P-RETURN P-MESSAGE /* Get Profiler state

    The state is coded in the field P-RETURN:

    P-RETURN Description
    0 Natural Profiler data collection is started.
    1 Natural Profiler data collection is paused.

Consolidating Event Data

The Profiler utility CONSOLIDATE function consolidates event data.

For general information regarding data consolidation, see Data Consolidation in the section Basic Concepts of the Profiler Utility.

Syntax of CONSOLIDATE:

FUNCTION=CONSOLIDATE
  [RESOURCE={ON|OFF}]
  [RESOURCE-NAME=resource-name]
  [RESOURCE-LIB=library-name]
  [REPLACE={YES|NO}]
  [TRANSACTION={ON|OFF}]
  [IO-TIME={ON|OFF}]
  [EXPORT={ON|OFF}]
  [FORMAT={TEXT|COMMA|SEMICOLON}]
  [TRACE-EVENT={ON|OFF}]
  [TRACE-CONSOLIDATE={ON|OFF}]

Syntax Description:

Keyword for CONSOLIDATE Value Description
RESOURCE   Specifies whether the consolidated event data is written to a Natural Profiler resource consolidated (NPRC) resource file.
ON The consolidated event data is written to an NPRC resource file.
OFF The consolidated event data is not written to an NPRC resource file.

This setting is useful if you want to print the event trace or statistics or export the data and you do not need the consolidated NPRC resource file.

RESOURCE-NAME resource-name The name of the Natural Profiler resource file (NPRF) you want to consolidate.

The file extension .nprf is added automatically.

Default: The name of the last created NPRF resource file in the library

If RESOURCE=ON, the consolidated data is written to an NPRC resource file with the same resource name.

RESOURCE-LIB library-name The name of the Natural library that contains the NPRF resource file you want to consolidate.

Default: The name of the current library.

This library is also used as the target library for the consolidated NPRC resource file.

REPLACE   Specifies whether an existing NPRC resource file is replaced.
YES Replace an existing NPRC resource file with the same name.
NO Do not replace an existing NPRC resource file with the same name.

A message is returned if a resource file with the same name already exists. No consolidation is performed in this case.

TRANSACTION   Specifies whether transaction identifiers are added to the consolidated event data.
ON Transaction identifiers are added to the consolidated event data for transaction evaluation purposes.

For more information, see Transaction Summary.

Note:
The generated NPRC resource file requires more space if ON is set.

OFF Transaction identifiers are not added to the consolidated event data.
IO-TIME   Specifies whether I/O time (IB event) and Natural RPC client time (RW event) are included in the consolidated data.
ON I/O and Natural RPC client time are included in the consolidated data.
OFF I/O and Natural RPC client time are not included in the consolidated data.
EXPORT   Specifies whether the consolidated event data is written to Work File 7.
ON Write to Work File 7.
OFF Do not write to Work File 7.
FORMAT   Specifies the format in which the exported data is written to Work File 7.
TEXT Write the data in free text format.
COMMA Write the data in CSV format with a comma (,) separator.
SEMICOLON Write the data in CSV format with a semicolon (;) separator.
TRACE-EVENT   Specifies whether the Profiler event trace is written to standard output.

See Event Trace.

ON Write the Profiler event trace.
OFF Do not write the Profiler event trace.
TRACE-CONSOLIDATE   Specifies whether the Profiler consolidation trace is written to standard output. See Consolidation Trace.
ON Write the Profiler consolidation trace.
OFF Do not write the Profiler consolidation trace.

Example of a Consolidation

The following example consolidates the Profiler resource Test.nprf in the library PRFDATA and writes the consolidated data to the Profiler resource Test.nprc. I/O and Natural RPC client time are included in the consolidated data.

In addition, the consolidated data is written in CSV (semicolon-separated values) format to Work File 7.

The event and consolidation traces are switched off.

FUNCTION=CONSOLIDATE    /* Consolidate Profiler data
  RESOURCE=ON           /* Write to resource
  RESOURCE-NAME='Test'  /* Resource name
  RESOURCE-LIB=PRFDATA  /* Resource library
  REPLACE=YES           /* Replace resource
  TRANSACTION=OFF       /* Do not add transaction identifiers 
  IO-TIME=ON            /* Include I/O and RPC client times
  EXPORT=ON             /* Write to Work File 7       
  FORMAT=S              /* CSV format with semicolon separator 
  TRACE-EVENT=OFF       /* No event trace
  TRACE-CONSOLIDATE=OFF /* No consolidation trace

Evaluating Event Data

When a Natural application is profiled, the Natural Profiler utility writes the event data to an NPRF resource file. Consolidated data is stored in an NPRC resource file and coverage data is stored in an NCVF resource file. The Profiler utility READ function reads and evaluates the Profiler resource data and writes the results to standard output or to a Natural work file. The evaluations performed depend on the type of the resource file read as described in the following table:

Resource File Type Evaluation Description
NPRF Event trace Chronological list of the Profiler event data
Program trace Program flow of the profiled application
Statistics Statistics of profiling and the NPRF resource file
NPRC Consolidation trace List of the consolidated data with hit counts and summarized elapsed time and CPU time
Program summary Table of executed Natural objects

The table shows which events occurred during object execution and the CPU time spent executing the object.

Line summary Table of executed Natural source lines

The table shows how many events occurred during line execution and the CPU and elapsed time spent executing the line.

Transaction summary Table of executed transactions.

The table shows which events occurred during transaction execution and the response time (elapsed time) of the transactions.

Statistics Statistics of profiling, the consolidation and the NPRC resource file
NCVF Statement coverage List of statements covered in in the source lines

The list shows the percentage of statement coverage for each statement line in the source of the accessed programs.

Program coverage Table of code coverage results of executed Natural objects

The program coverage table lists all Natural objects which have been executed during the coverage run. For each object, it shows the percentage of coverage, the number of covered and missed statements, and the total number of statements.

Statistics Statistics for profiling, coverage and the NCVF resource file

This section covers the following topics:

Profiler Utility READ Function

The Profiler utility READ function reads and evaluates the resource data.

Syntax of READ:

FUNCTION=READ
  [RESOURCE-NAME=resource-name]
  [RESOURCE-LIB=library-name]
  [RESOURCE-TYPE={NPRF|NPRC|NCVF}]
  [EVENT={ON|OFF}]
  [PROGRAM={ON|OFF}]
  [LINE={ON|OFF}]
  [TRANSACTION={ON|OFF}]
  [STATISTICS={ON|OFF}]
  [PRINT={ON|OFF}]
  [EXPORT={ON|OFF}]
  [FORMAT={TEXT|COMMA|SEMICOLON}]

Syntax Description:

Keyword for READ Value Description
RESOURCE-NAME resource-name The name of the NPRF, NPRC or NCVF resource file you want to read.

If no file extension is specified, the extension specified with the keyword RESOURCE-TYPE is added automatically.

Default: The name of the last created NPRF, NPRC or NCVF resource file in the library depending on the RESOURCE-TYPE specification

RESOURCE-LIB library-name The name of the Natural library that contains the NPRF, NPRC or NCVF resource you want to read.

Default: The name of the current library

RESOURCE-TYPE   Specifies the default resource type (extension) to use if no extension is specified with RESOURCE-NAME.
NPRF The default resource type is NPRF with extension .nprf.
NPRC The default resource type is NPRC with extension .nprc.
NCVF The default resource type is NCVF with extension .ncvf.
EVENT   Specifies whether the Natural Profiler evaluates events.

See also Event Trace, Consolidation Trace and Statement Coverage.

ON

NPRF: Write the Natural Profiler event trace.
NPRC: Write the Natural Profiler consolidation trace.
NCVF: Write the statement coverage result.

OFF Do not evaluate events.
PROGRAM   Specifies whether the Natural Profiler evaluates programs.

See also Program Trace, Program Summary and Program Coverage.

ON

NPRF: Write the Natural Profiler program trace.
NPRC: Write the Natural Profiler program summary.
NCVF: Write the program coverage table.

OFF Do not evaluate programs.
LINE   This option is only available for NPRC resources.

Specifies whether the Natural Profiler evaluates executed source lines.

See also Line Summary.

ON Write the Natural Profiler line summary.
OFF Do not evaluate executed source lines.
TRANSACTION   This option is only available for NPRC resources.

Specifies whether the Natural Profiler evaluates transactions.

For more information, see Transaction Summary.

ON Evaluate transactions to generate a transaction summary and show transaction-related values in the program summary and the line summary.
OFF Do not evaluate transactions.
STATISTICS   Specifies whether the Natural Profiler writes statistics.

See also Profiler Statistics.

Note:
Statistics data for Natural code coverage is not collected on UNIX and Windows.

ON Write statistics.
OFF Do not write statistics.
PRINT   Specifies whether the result is written to standard output.
ON Write to standard output.
OFF Do not write to standard output.
EXPORT   Specifies whether the evaluated data is written to the Work File 7.
ON Write to Work File 7.
OFF Do not write to Work File 7.
FORMAT   Specifies the format in which the exported data is written to Work File 7.
TEXT Write the data in free text format.
COMMA Write the data in CSV format with a comma (,) separator.
SEMICOLON Write the data in CSV format with a semicolon (;) separator.

Example of READ

The following example reads the Natural Profiler resource Test.nprf in the library PRFDATA and writes the event trace, program trace and the Profiler statistics to standard output and to Work File 7 in text format.

FUNCTION=READ           /* Read Profiler Data
  RESOURCE-NAME='Test'  /* Resource name
  RESOURCE-LIB=PRFDATA  /* Resource library
  RESOURCE-TYPE=NPRF    /* Use resource type NPRF
  EVENT=ON              /* Print event trace
  PROGRAM=ON            /* Print program trace
  STATISTICS=ON         /* Print statistics
  PRINT=ON              /* Write to standard output
  EXPORT=ON             /* Write to Work File 7
  FORMAT=TEXT           /* Export in text format

Event Trace

If EVENT=ON is specified for an NPRF resource file, the Profiler event trace is generated.

The event trace shows the data of each Natural event which occurred while the application executed. The trace can be referenced if detailed information of an event is required. For example, if a Natural error occurred during application execution, the event trace shows the corresponding error number and message.

If the event trace is written to standard output (PRINT=ON) or exported in text format (EXPORT=ON, FORMAT=TEXT), it is similar to the event trace written by the Profiler monitor session while the application was profiled (see Event Trace). If the data is exported in CSV (comma-separated values) format, it contains all data fields provided by the Profiler (see Data Collected).

Example of an Event Trace

The following example shows an extract of an event trace:

Natural Profiler Event Trace
----------------------------
     Count Time              CPU-Time (ms) Ev Lev Library  Program  Line CC-Lib   CC-Name  Statement  Local-Data
         0 10:20:58.219911        63.318   MP 003 SYSPRFD  PRBINIT  8350                   Call       Monitor pause requested
       102 10:20:58.277586        76.106   PL 000                   0000                              Execute SYSEDMD/MENU
       103 10:20:58.277591        76.139   PS 001 SYSEDMD  MENU     0000                   PgmStart   00010/02430 Type: P
       103 10:20:58.277594        76.151   NS 001 SYSEDMD  MENU     0250                   Compute    Assign/Compute/Move
       103 10:20:58.277596        76.155   NS 001 SYSEDMD  MENU     0270                   Fetch      Fetch
       104 10:20:58.277598        76.169   DB 001 SYSEDMD  MENU     0270                   Fetch      00010/02430 S1
...

Explanations:

  • The Count column shows the number of the event.

  • The Time and CPU-Time columns show the event time and the CPU timestamp of the event execution, respectively.

  • The event with the number 104 is a Database Before (DB) event caused by an Adabas S1 command issued against the file 00010/02430 which was triggered by a FETCH statement in the line 0270 of the Natural object MENU.

For further explanations of the trace columns and event types, see the sections Event Trace and Events and Data Collected.

Consolidation Trace

If EVENT=ON is specified for an NPRC resource file, the Natural Profiler consolidation trace is generated. The consolidation trace is also generated if TRACE-CONSOLIDATE=ON is set for the Profiler utility CONSOLIDATE function.

The consolidation trace shows general event data, summarized values of the elapsed time and CPU time and the hit count of the consolidated record. If two trace entries show the same general event data, they have different event-specific data which is not displayed in the consolidation trace.

The consolidated records are used as the basis for further evaluations like the NaturalONE hot spots or the Natural Profiler MashApp. The consolidation trace can be used to validate the consolidated data.

If the consolidation trace is written to standard output (PRINT=ON), it is similar to the consolidation trace written by the Profiler data consolidation (see Consolidating Event Data). If the data is exported, it contains all consolidated data fields provided by the Profiler.

Example of a Consolidation Trace

The following example shows an extract of a consolidation trace:

Natural Profiler Consolidation Trace
------------------------------------
    Count Transact Ev User     Lev Library  Program  Line CC-Lib   CC-Name  Statement   Hit-Count  Elapsed(ms)      CPU(ms)
        1          DA PRFO82D  000                   0000                                       1       75.692        0.870
        2          DA PRFO82D  000                   0000                                       1        0.002        0.004
        3          DA PRFO82D  000                   0000                                       1        0.006        0.025
        4          NS PRFO82D  006 SYSLIBS  A82CLS   0010 SYSAOSSU C-COPYRT Reset              43        0.043        0.118
        5          NS PRFO82D  006 SYSTEM   NOMSTCS  4360                   End                 1        0.000        0.003
        6          PL PRFO82D  006 SYSTEM   NOMSTCS  0970                   Callnat             1        0.008        0.058
        7          PL PRFO82D  006 SYSTEM   NOMSTCS  1020                   Perform             1        0.004        0.017
...

Explanations:

  • The Count column shows the number of the consolidated record.

  • The Transact column shows the transaction identifier.

    The transaction identifier starts with 1 and is increased with every IA (after terminal I/O) or RI (inbound RPC message) event. Transaction identifiers are only available if data is consolidated with the option TRANSACTION=ON.

  • The consolidated record 4 shows that the RESET statement in the line 0010 of the copycode C-COPYRT (included in the Natural object A82CLS) executed 43 times spending a total elapsed time of 0.043 milliseconds (ms) and a total CPU time of 0.118 ms.

For further explanations of the trace columns and event types, see the sections Event Trace and Events and Data Collected.

Program Trace

If PROGRAM=ON is specified for an NPRF resource file, the Profiler program trace is generated. The program trace shows the program flow of the profiled application. In general, the program trace exclusively shows program and session events (see Events and Data Collected for a list of possible event types).

If the program trace is written to standard output (PRINT=ON) or exported in text format (EXPORT=ON, FORMAT=TEXT), the program names are indented (see the example below) according to the program level to provide a quick overview of the application calling structure.

If the data is exported in CSV (comma-separated values) format, the program names are not intended. In addition to the output in text format, the exported data contains the CPU timestamp and the summarized Adabas time.

Example of a Program Trace

The following example shows an extract of a program trace and the totals of the application run:

Natural Profiler Program Trace
------------------------------
Time            Ev Library  CC-Name  Line Lev Program  Events
10:20:58.309812 PL                   0000 000
10:20:58.309817 PS SYSEDMD           0000 001 .OPTTEST  D=4 N=2
10:20:58.357694 PL SYSEDMD           5620 001 .OPTTEST
10:20:58.357704 PS SYSEDMD           0000 002 ..CALLMON3 N=3
10:20:58.385263 PL SYSEDMD           0980 002 ..CALLMON3
10:20:58.385274 PS SYSEDMD           0000 003 ...OP3DISC  D=3 N=4
10:20:58.412207 PL SYSEDMD           1670 003 ...OP3DISC
10:20:58.412221 PS SYSEDMD           0000 004 ....OPTINFO  N=57
10:20:58.443203 PL SYSEDMD           5830 004 ....OPTINFO
10:20:58.443210 PS SYSEDMD           0000 005 ....:OPTPARM1 D=3 N=19
10:20:58.449549 PL SYSEDMD           1960 005 ....:OPTPARM1
10:20:58.449555 PS SYSEDMD           0000 006 ....:.OPTPARM2 D=3 N=10
10:20:58.458286 PL SYSEDMD           0560 006 ....:.OPTPARM2
10:20:58.458300 PS SYSEDMD           0000 007 ....:..OPTPARM3 N=16
10:20:58.458390 PL SYSEDMD           1530 007 ....:..OPTPARM3
10:20:58.458408 PS SYSLIBS           0000 008 ....:...NAT41004 D=10 C=6 N=7345
10:20:58.471017 PT SYSLIBS           5235 008 ....:...NAT41004
10:20:58.471017 PR SYSEDMD           1530 007 ....:..OPTPARM3 N=2898
10:20:58.473293 PL SYSEDMD           1530 007 ....:..OPTPARM3
10:20:58.473297 PS SYSLIBS           0000 008 ....:...NAT41004 D=5 C=6 N=1416
10:20:58.475581 PT SYSLIBS           5235 008 ....:...NAT41004
10:20:58.475581 PR SYSEDMD           1530 007 ....:..OPTPARM3 N=466
10:20:58.475957 PT SYSEDMD           2190 007 ....:..OPTPARM3
10:20:58.475957 PR SYSEDMD           0560 006 ....:.OPTPARM2 N=283
10:20:58.476187 PT SYSEDMD           0860 006 ....:.OPTPARM2
10:20:58.476187 PR SYSEDMD           1960 005 ....:OPTPARM1 N=42
10:20:58.476222 PT SYSEDMD           7510 005 ....:OPTPARM1
10:20:58.476222 PR SYSEDMD           5830 004 ....OPTINFO  D=3 N=10
10:20:58.497926 PL SYSEDMD           6080 004 ....OPTINFO
10:20:58.521954 PR SYSEDMD           1670 003 ...OP3DISC  N=241
10:21:11.205102 PR SYSEDMD           0980 002 ..CALLMON3 D=7 N=6070
10:21:41.704996 PR SYSEDMD           5620 001 .OPTTEST  D=8 I=3 N=26
10:21:41.731229 PT SYSEDMD           7370 001 .OPTTEST
10:21:41.731229 PR                   0000 000          D=14 I=1
10:21:42.248348 ST                   0000 000

Totals
------
Ev Event                    Count
S  Session ................ 1
P  Program ................ 5297
D  Database Call .......... 2140
I  Terminal I/O ........... 12
C  External Program Call .. 6510
E  Runtime Error .......... 43
N  Natural Statement ...... 857384
R  RPC Request............. 0
U  User-Defined Event ..... 0
M  Monitor Pause .......... 2

Explanations:

  • For each event listed, the time when the event occurred, the active library, program (Natural object), copycode, line number and program level is displayed.

  • The program name is followed by the number of events that occurred from one program event to the next program event.

  • Events which belong to one event group are combined into one count using the maximum count of the corresponding event types. Example: One Database Before (DB) and one Database After (DA) event are combined into one Database event (D=1).

  • In the example above, the Natural object OPTTEST was started at the level 1. This program calls the subprogram CALLMON3 which calls further subprograms. The highest Level 8 is reached when the subprogram NAT41004 executes. During the first execution, this subprogram performs 10 database calls (D=10), 6 external program calls (C=6) and 7345 Natural statements (N=7345).

  • The Totals section at the end of the program trace shows the maximum count of each event group. For example: a total of 2140 database calls corresponds to 2140 Database Before (DB) and 2140 Database After (DA) events.

  • The totals of the Session (S) and Program (P) event groups are only listed under Totals; they are not listed next to the program name.

For further explanations of the trace columns, see the section Event Trace.

For explanations of event types and associated event groups, see the section Events.

Program Summary

If PROGRAM=ON is specified for an NPRC resource file, the Profiler program summary is generated.

The program summary shows for each Natural object how many Natural events have occurred, the total CPU time (in milliseconds) and the percentage of the CPU time spent by the Natural object with respect to the total CPU time.

Monitor Pause events and events at Level 0 are not taken into account for the program summary. Events which belong to one event group are combined into one count: see Events.

Program starts and load requests are listed separately.

If the data is exported in CSV (comma-separated values) format, the count of each event type is listed. Additionally, the elapsed time and the Adabas times (absolute and percentage values) are displayed. The exported time values are indicated in microseconds.

Example of a Program Summary

The following example shows the extract of a program summary:

Natural Profiler Program Summary                                                                                      
--------------------------------                                                                                      
Library  Program      Start      Load  Database       I/O  External     Error Statement      User CPU-Time (ms)  CPU %
SYSEDMD  ADA-CL          41         0        40         0        41         0       621         0         3.785   0.14
SYSEDMD  ADA-RC          45         0        44         0        45         0       545         0         4.704   0.17
SYSEDMD  AOS-CL         115        97        15         0         0         0      2507         0        42.890   1.63
SYSEDMD  AOS-OP         169       154        22         0         0         0      6975         0        70.286   2.68
SYSEDMD  BYTE             1         0         0         0         0         0        11         0         0.034   0.00
SYSEDMD  CALLMON3         1         5        23         0         0         0      7089         0        20.001   0.76
SYSEDMD  CALLNOM          6         6        19         0         0         0        18         0         1.342   0.05
SYSEDMD  CALLNOPM         2         2         4         0         0         0        16         0         0.395   0.01
SYSEDMD  CALLNOPN         1         1         4         0         0         0         8         0         0.244   0.00
SYSEDMD  CALLNOPS         3         4        23         0         0         1        31         0         1.841   0.07
SYSEDMD  DISNOP           1         7         6         0         0         0       515         0         2.260   0.08
SYSEDMD  DISNO4I          1        47         3         0         1         0      8075         0        25.516   0.97
SYSEDMD  DISNO4IS        57         0         0         0       624         0     36877         0       105.650   4.03
SYSEDMD  DISNRS           1         0         0         0        44         0       511         0         3.343   0.12
SYSEDMD  DISNSP           1        18        15         0         0         0      1850         0         6.074   0.23
SYSEDMD  DISNTMZ          1         4        11         0         0         0       324         0         2.309   0.08
SYSEDMD  MENU             1         1         3         0         0         0         2         0         0.235   0.00
SYSEDMD  MONACSH          1         6         6         0         0         0      1217         0         3.470   0.13
SYSEDMD  MONADA           1      3176        71         0         0         0    272180         0       680.214  25.98
SYSEDMD  MONAREP          1         9        28         0         0         0      1964         0         6.378   0.24
...
Total                  5294      5293      2122         7      6510        43    857384         0      2617.326 100.00

Explanations:

  • The Natural object MONADA consumed the most CPU time: 680.214 ms which corresponds to 25.98 percent of the total CPU time.

  • MONADA was started once, it loaded 3176 other Natural objects, performed 71 database calls and 272180 Natural statements. There was no I/O, no external call and no error in the program.

  • At the end of the program summary, the Total counts of the profiling are listed.

Line Summary

If LINE=ON is specified for an NPRC resource file, the Profiler line summary is generated.

The line summary shows for each source line in a Natural object, the number of Natural events that occurred (hit count), the CPU and elapsed time (in milliseconds and percent) spent by the line. The percentage of times is calculated in relation to the total times of the application.

The line summary does not count Monitor Pause events and events at Level 0.

If the data is exported in CSV (comma-separated values) format, the count of each event type is listed. Additionally, the Adabas times (absolute and percentage values) are displayed. The exported time values are indicated in microseconds.

Example of a Line Summary

The following example shows the extract of a line summary:

Natural Profiler Line Summary                                                                
--------------------------------                                                             
Library  Program  Line CC-Lib   CC-Name  Hit-Count       CPU (ms)  CPU %  Elapsed (ms)  Ela %
PRFTEST  XINT     0000                            1         0.016   0.46         0.003   0.01
PRFTEST  XINT     0140                            1         0.005   0.14         0.001   0.00
PRFTEST  XINT     0150                            1         0.006   0.17         0.002   0.01
PRFTEST  XINT     0160                            1         0.004   0.11         0.001   0.00
PRFTEST  XINT     0170                           23         0.128   3.75         0.029   0.18
PRFTEST  XINT     0180                           10         0.049   1.43         0.012   0.07
PRFTEST  XINT     0190                           10         0.054   1.58         0.010   0.06
...
Total                                           371         3.408 100.00        15.992 100.00

Explanations:

  • Line 0170 in the Natural object XINT consumed 0.128 ms of the CPU time and 0.029 ms of the elapsed time. This corresponds to 3.75 percent of the total CPU time and 0.18 percent of the total elapsed time. 23 events (hit count) were executed in the line.

  • At the end of the line summary, the Total counts of the profiling are listed.

Transaction Summary

A transaction is the code executed between two consecutive terminal I/O operations. The elapsed time spent on executing a transaction is called response time.

The transaction summary generated by the Profiler shows how many Natural events have occurred for each transaction, the response time (in milliseconds) and the percentage of the response time spent by the transaction with respect to the total response time.

Prerequisites Required for Transaction Evaluations

The Profiler data must be consolidated with the CONSOLIDATE function set to TRANSACTION=ON so that the consolidated data records in the NPRC resource file contain transaction identifiers required for evaluating the transaction response time.

TRANSACTION=ON is specified for the READ function.

Event Data Evaluated for Transactions

In general, one terminal I/O event relates to one transaction. The number of terminal I/O events is not listed in standard output (for PRINT=ON).

Data exported in CSV (comma-separated values) format contains the count of each event type, including terminal I/O. Additionally, the data list contains the CPU time and the Adabas times (absolute and percentage values). Exported time values are indicated in microseconds.

The transaction summary does not consider Before Terminal I/O (IB) events, RPC Wait for Client (RW) events, Monitor Pause (MP) events and events at Level 0. Events that belong to one event group are combined into one count.

For explanations of event types and associated event groups, see the section Events.

Modified Line and Program Summary

If TRANSACTION=ON is specified for the READ function of an NPRC resource file, the program summary and the line summary also consider the transaction identifier and aggregate the program and line values for each transaction separately. In the transaction line summary, the ID column indicates the program line in which the transaction was started.

Example of a Transaction Summary

The following example shows a transaction summary:

Natural Profiler Transaction Summary                                                                                     
------------------------------------                                                                                     
Transact TA-Lib   TA-Prog  TA-CC TA-Line   Program  Database  External     Error Statement      User  Elapsed (ms)  Time%
       1                                         1         0         1         0         0         0         0.829   0.50
       2 SYSPRFLR PRFMENM           0020         9        13         8         0         0         0        17.618  10.65
       3 SYSEDM   MOPTTEST          0020         4         0         0         0         0         0         6.167   3.72
       4 SYSEDM   OPTWLS80          0470         0         0         0         0         0         0         1.108   0.66
       5 SYSEDM   OPTWLS80          0470         2         0         0         0         0         0         1.133   0.68
       6 SYSEDM   OPTTEST           1750         1         0         0         0         0         0         1.180   0.71
       7 SYSEDM   MOPTTEST          0020        27        33        30         0         0         0        94.236  56.96
       8 SYSEDM   OPTTEST           5590         1         0         0         0         0         0         1.185   0.71
       9 SYSEDM   MOPTTEST          0020        37        33        56         0         0         0        37.311  22.55
      10 SYSEDM   OPTTEST           5760         1         0         0         0         0         0         1.096   0.66
      11 SYSEDM   MOPTTEST          0020         6         0         6         0         0         0         2.164   1.30
      12 SYSPRFLR PRFMENM           0020         2         0         3         0         0         0         1.394   0.84
Total                                           86        79       103         0         0         0       165.421 100.00

Explanations using the example of Transaction 7:

  • Transaction 7 spent the longest response (elapsed) time: 94.236 milliseconds (ms) which correspond to 56.96 percent of the total response time.

  • Transaction 7 started an I/O operation in the library SYSEDM (TA-Lib column), program MOPTTEST (TA-Prog), program line 0020 (TA-Line).

  • Transaction 7 accessed 27 programs and issued 33 database calls and 30 external program calls.

  • In the example above, all counters for statement events are 0 because statement events were not collected during this Profiler run.

  • At the end of the transaction summary, the Total counts of the profiled transactions are listed.

Program Coverage

The program coverage table is generated if PROGRAM=ON is specified for an NCVF resource file.

The program coverage table shows the code coverage results for each accessed Natural object. If the table is given in text format, only the GP coverage results (copycodes included) are displayed. In CSV (comma-separated values) format, the table shows lines containing copycode values, additional columns with source counters (copycodes not included) and information regarding INCLUDE statements.

In text format, the table provides the coverage count for each accessed library and for the whole application.

The table contains the following columns:

Column Description
Evaluation The type of evaluation. Possible types are:
Program For program coverage data
Event For statement coverage data
Statistics For Profiler statistics data
Object Count The count of cataloged objects (GPs) listed in the table.
Object Type The type of Natural object such as program and subprogram.
Library The Natural library that contains the object.
Object The name of the Natural object.
Copycode ID The unique identifier of the copycode instance in the cataloged object (GP). The program gets the copycode ID 0.
Copycode Library The library from which the copycode is included.
Copycode Name The name of the copycode.
GP Coverage% The percentage of object coverage whereby INCLUDE statements are resolved.
GP Covered The number of covered (executed) statements whereby INCLUDE statements are resolved.
GP Missed The number of missed (not executed) statements in the object whereby INCLUDE statements are resolved.
GP Total The total number of all executable statements in the object whereby INCLUDE statements are resolved.
Src Coverage% The percentage of object coverage whereby INCLUDE statements are not resolved.
Src Covered The number of covered (executed) statements whereby INCLUDE statements are not resolved.
Src Missed The number of missed (not executed) statements in the object whereby INCLUDE statements are not resolved.
Src Total The total number of all executable statements in the object whereby INCLUDE statements are not resolved.
First Statement The ID of the first statement of the object or copycode.
INCLUDE CC-ID For copycode only.

The copycode ID of the object or copycode that includes the copycode.

INCLUDE Object For copycode only.

The name of the object or copycode that includes the copycode.

INCLUDE Line For copycode only.

The line number of the INCLUDE statement that includes the copycode.

Example of Program Coverage

The following example shows the result of program coverage in text format:

Program Coverage
----------------
Library   Object   Ty Coverage%  Covered    Missed    Total
COVDEMO   TESTCOVN N      78.5%       11         3       14
COVDEMO   TESTCOVP P      57.1%        4         3        7
COVDEMO   -------- --     71.4%       15         6       21
Totals    -------- --     71.4%       15         6       21

Explanations:

  • The application accesses two objects, the TESTCOVN subprogram (N) and the TESTCOVP program (P).

  • In TESTCOVN, there are 14 executable statements from which 11 were covered (executed) and 3 missed (not executed), giving a total coverage of 78.5%.

  • The summarized values of the two objects accessed in the library COVDEMO show coverage of 71.4%.

  • Total coverage is also 71.4% because only one library is accessed by the objects.

Statement Coverage

Statement coverage is generated if EVENT=ON is specified for an NCVF resource file.

For statement coverage, the Profiler utility reads the source of the monitored objects. If the source is not found or if the source does not match the collected data, source lines are not printed in the statement coverage report. The Profiler utility resolves INCLUDE statements and merges the source of the corresponding copycode into the including program. If the INCLUDE structure cannot be resolved, the copycodes are printed separately.

We recommend that you perform the READ function soon after the coverage run, as long as the sources correspond to the monitored GPs. As soon as the sources have been modified, the Profiler utility can no longer provide the full information.

Statement coverage shows the percentage of statements covered for each source line of the accessed programs. If the result is written in text format, for each object listed in the statistics, the object coverage values are shown before the statement coverage data. If the result is written in CSV (comma-separated values) format, additional information regarding statement coverage is provided.

The table contains the following columns:

Column Description
Evaluation The type of evaluation. Possible types are:
Program For program coverage data
Event For statement coverage data
Statistics For Profiler statistics data
Object Count The count of objects (GPs) listed in the table.
Library The Natural library that contains the objects.
Object The name of the Natural object.
Copycode ID The unique identifier of the copycode instance in the related cataloged object. The program gets the copycode ID 0.
Copycode Library The library that contains the copycode (if copycode is active).
Copycode Name The name of the copycode (if copycode is active).
Line The line number in the Natural source object, for example, 0120.
Source The Natural source line that contains a statement definition, for example, MOVE #A TO #B.
Coverage% The percentage of statement coverage of the line.
Covered The number of statements covered (executed) in the line.
Missed The number of missed (not executed) statements in the line.
Total The total number of all executable statements (object code instructions) in the line.
Item Coverage Indicates which statement items (object code instructions) in the line have been covered or missed. Each statement is represented by either 1 or 0, whereby 1 indicates a covered statement and 0 a missed statement. For example: A value of x100 indicates that only the first of three statements in the line is covered.
Mark Indicates the coverage state of the line.

The Mark column can be used to visualize the coverage results in tools like Microsoft Excel. Possible Mark values are listed in Using a Microsoft Excel Template to Visualize Coverage Results.

Example of Statement Coverage

The following example assumes that the development has delivered a new version of the TESTCOVN subprogram to the quality engineering. After running the test programs, statement coverage of the subprogram shows the following result (text format):

M Cov% CC-Lib   CC-Name  Line Source
*                        0010 * Test function Coverage 
*                        0020 * Subprogram TESTCOVN 
+                        0030 DEFINE DATA 
+                        0040 PARAMETER 
+                        0050 1 FUNC     (I2)  /* function 
+                        0060 1 RET-CODE (I4)  /* Return code 
+                        0070 END-DEFINE 
*                        0080 * 
*                        0090 /* Return 0 by default 
C 100%                   0100 RESET RET-CODE 
*                        0110 * 
C 100%                   0120 DECIDE ON FIRST VALUE OF FUNC 
+                        0130   VALUE 0 
+                        0140     PRINT 'Test function 0' 
+                        0150   VALUE 1 
C 100%                   0160     PRINT 'Test function 1' 
+                        0170   VALUE 2 
C 100%                   0180     PRINT 'Test function 2' 
+                        0190   VALUE 3 
C 100%                   0200     PRINT 'Test function 3' 
+                        0210   VALUE 4 
C 100%                   0220     PRINT 'Test function 4' 
+                        0230   VALUE 5 
C 100%                   0240     PRINT 'Test function 5' 
+                        0250   VALUE 6 
C 100%                   0260     PRINT 'Test function 6' 
+                        0270   VALUE 7 
C 100%                   0280     PRINT 'Test function 7' 
+                        0290   VALUE 8 
C 100%                   0300     PRINT 'Test function 8' 
+                        0310   VALUE 9 
+                        0320     PRINT 'New test function 9' 
+                        0330   NONE VALUE 
+                        0340     RET-CODE := 1  /* Unsupported function 
+                        0350 END-DECIDE 
*                        0360 * 
C 100%                   0370 END

Explanations:

  • The Mark (M) column shows whether a line is covered (C).

  • No test cases cover the functions Test function 0 and New test function 9. The NONE VALUE case is also not covered.

  • All other test cases are covered (denoted with C and 100% coverage).

As a consequence of this coverage analysis, the test cases have to be adjusted so that Test function 0 and Test function 9 (and, perhaps, the error case with an unsupported function code) are also covered.

Using a Microsoft Excel Template to Visualize Coverage Results

Prerequisites: Microsoft Excel and Natural for Windows or Natural for UNIX.

If you want to analyze the coverage result with Microsoft Excel, you can use the Microsoft Excel template delivered with Natural for Windows and Natural for UNIX. Perform the following steps:

  1. Perform the Profiler READ function and write the output data in CSV (comma-separated values) format to Work File 7. For example:

    FUNCTION=READ           /* Read Profiler Data
      RESOURCE-NAME='Test'  /* Resource name
      RESOURCE-LIB=PRFDATA  /* Resource library
      RESOURCE-TYPE=NCVF    /* Use resource type NCVF
      EVENT=ON              /* Print statement coverage
      PROGRAM=ON            /* Print program coverage
      STATISTICS=ON         /* Print statistics
      PRINT=ON              /* Write to standard output
      EXPORT=ON             /* Write to Work File 7
      FORMAT=COMMA          /* Export in CSV format
  2. If your Microsoft Excel requires semicolons as separators, specify the following:

    FORMAT=SEMICOLON      /* Export in CSV format
  3. Export the data of Work File 7 with any tool (such as FTP) as a CSV-formatted file to a Windows environment.

  4. Open the CSV file with Microsoft Excel.

  5. Rearrange the data so that each evaluation type (program, event, statistics) is on its own worksheet in the Microsoft Excel file.

  6. Open the delivered template TESTCOV.XLSX with Microsoft Excel. The template is contained in the RES (Resources) subdirectory of the Natural SYSPRFLR system library.

  7. For each worksheet, copy the format from the template to your Microsoft Excel:

    • Click on the upper left corner of the table in the template to mark all data in the table.

    • Click on the Microsoft Excel Copy format function.

    • Click on the upper left corner of the table in your worksheet to copy the format.

      Now, all entries are formatted as in the template. The source lines are colored and marked as follows:

      Color Mark Description
      Green C All statements in the line are covered.
      Yellow P The statements in the line are partly covered.
      Pink M All statements in the line are missed.
      Gray * A comment or an empty line.
      Red E Error encountered.

      For example, if the coverage analysis has collected a line number but the corresponding source line is not found.

      None (white) + All other lines such as continuation lines of a statement.

Example of a Microsoft Excel Worksheet

The following example shows a worksheet extract of code coverage for the TESTCOVP program with included TESTCOVC copycode without the columns that contain the object name and library:

graphics/profiler_excel_coverage_luw.png

Explanations:

  • The source lines of the TESTCOVC copycode are included in the source of the TESTCOVP program and placed right after the corresponding INCLUDE statement.

  • The lines 40 through 70 of the copycode contain statements which were not executed in the test run.

  • All other lines (in green) containing executable statements are covered.

Statistics

If STATISTICS=ON is specified, the Profiler statistics are listed.

Note:
Statistics are not provided for an NCVF file on UNIX or Windows.

If the data is exported in CSV (comma-separated values) format, the properties and values of the Profiler statistics are added as separate columns to the event or consolidation trace. If coverage data is exported in CSV format, the statistics values are added in additional lines indicated by the value Statistics in the Evaluation column.

Example of Statistics

The following example shows an extract of the statistics of an NPRC resource file:

***************************************************************************  
* 17:35:59          ***** NATURAL PROFILER UTILITY *****         2016-01-11  
* User SAGTEST1                - Statistics -                       RESDATA  
...
*                                                                            
* Profiler Resource File                                                     
* Resource name ...................... EDM-MONITOR.nprc                      
* Resource type ...................... Natural Profiler Resource Consolidated
* Resource allocation date ........... 2015-07-27 10:36:19.6                 
* Resource size (bytes) .............. 565160     
...
*                                                
* Data Processing                                
* Number of events ................... 895936     
...
*                                                
* Data Consolidation                             
* Consolidation ...................... ON        
* Consolidation records .............. 21624     
* Consolidation elapsed time (sec) ... 15.643516 
* Consolidation factor ............... 41.4 
* Consolidation records/block ........ 191.3
* Bytes/consolidation record ......... 25.8 
*
...                                           
***************************************************************************

Explanations:

  • The EDM-MONITOR.nprc resource was allocated on 2015-07-27 at 10:36:19 a.m. and has a size of 565160 bytes.

  • The profiled application generated a total of 895936 Natural events. The data consolidation took 15.6 seconds and reduced the number of records to 21624 which corresponds to a consolidation factor of 41.4.

All statistics information provided is explained in the section Profiler Statistics.

Note:
The Natural Profiler for UNIX and Windows does not collect statistical data. The statistics provided are values determined by the Profiler utility.

Exporting Event Data for MashZone

You can visualize Profiler event data on an interactive MashZone dashboard by using the Natural Profiler MashApp.

The Profiler utility MASHZONE function reads the consolidated data of an NPRC resource file and writes the data to Work File 7 in the format expected by the Natural Profiler MashApp. Use as Work File 7 a CSV (comma-separated values) file in the Natural Profiler data directory in the MashZone environment which can be accessed by the Natural Profiler MashApp.

Syntax of MASHZONE:

FUNCTION=MASHZONE
  [RESOURCE-NAME=resource-name]
  [RESOURCE-LIB=library-name]

Syntax Description:

Keyword Value Description
RESOURCE-NAME resource-name The name of the Natural Profiler resource consolidated (NPRC) file to be exported for MashZone.

The extension .nprc is added automatically.

Default: The name of the last created NPRC resource file in the library

RESOURCE-LIB library-name The name of the Natural library that contains the NPRC resource file you want to export.

Default: The name of the current library

Alternative Function Specifications

READ

The following Profiler utility READ function is equivalent to the MASHZONE function and generates the same export data:

FUNCTION=READ
  RESOURCE-NAME=resource-name
  RESOURCE-LIB=library-name
  RESOURCE-TYPE=NPRC
  EVENT=ON
  PROGRAM=OFF
  LINE=OFF
  TRANSACTION=OFF   
  STATISTICS=ON
  PRINT=OFF
  EXPORT=ON
  FORMAT=SEMICOLON
CONSOLIDATE

The Natural Profiler MashApp can also process data exported with the Profiler utility CONSOLIDATE function if you specify the following keywords:

FUNCTION=CONSOLIDATE    /* Consolidate Profiler data
  TRANSACTION=ON        /* Add transaction identifiers
  EXPORT=ON             /* Write to Work File 7
  FORMAT=SEMICOLON      /* CVS format with semicolon separator 
  ...

Example of MASHZONE

The following example reads the consolidated Profiler resource Test.nprc in the library PRFDATA. The data is written in CSV (comma-separated values) format to Work File 7 which can be accessed by MashZone.

FUNCTION=MASHZONE       /* Export Profiler data for MashZone
  RESOURCE-NAME='Test'  /* Resource name
  RESOURCE-LIB=PRFDATA  /* Resource library

Maintaining Profiler Resource Files

In general, Profiler resources are listed as NPRF, NPRC or NCVF files by using the Natural SYSMAIN utility, NaturalONE or Natural Studio. These tools also provide functions to copy, rename and delete resource files.

In addition, you can use Profiler utility functions to list Profiler resource files.

This section covers the following topic:

Listing Profiler Resource Files

The Profiler utility LIST function lists the Profiler resource files of a given Natural library and the date and time when the resource files were allocated.

Syntax of LIST:

FUNCTION=LIST
  [RESOURCE-LIB=library-name]
  [RESOURCE-TYPE={NPRF|NPRC|NCVF}]
  [PRINT={ON|OFF}]
  [EXPORT={ON|OFF}]
  [FORMAT={TEXT|COMMA|SEMICOLON}]

Syntax Description:

Keyword for LIST Value Description
RESOURCE-LIB library-name The name of the Natural library that contains the Profiler resource files you want to list.

Default: The name of the current library

RESOURCE-TYPE   Specifies the type of resource files to be listed: NPRF, NPRC or NCVF.

Default: All types are listed if no value is specified here.

NPRF List NPRF (Natural Profiler Resource File) resource files only.
NPRC List NPRC (Natural Profiler Resource Consolidated) resource files only.
NCVF List NCVF (Natural code coverage file) resource files only.
PRINT   Specifies whether the result is written to standard output.
ON Write to standard output.
OFF Do not write to standard output.
EXPORT   Specifies whether the result is written to Natural Work File 7.
ON Write to Work File 7.
OFF Do not write to Work File 7.
FORMAT   Specifies the format in which the exported data is written to Work File 7.
TEXT Write the data in free text format.
COMMA Write the data in CSV format with a comma (,) used as a separator.
SEMICOLON Write the data in CSV format with a semicolon (;) used as a separator.
Example of LIST

The following example lists the NPRF Profiler resource files of library PRFDATA. The list is written to standard output and to Work File 7 in text format.

FUNCTION=LIST           /* List Profiler resource files
  RESOURCE-LIB=PRFDATA  /* Resource library
  RESOURCE-TYPE=NPRF    /* List NPRF resource files
  PRINT=ON              /* Write to standard output
  EXPORT=ON             /* Write to Work File 7
  FORMAT=TEXT           /* Export in text format

Output:

Natural Profiler Resources
--------------------------
Library: PRFDATA
Resource type: nprf
 
Count Date       Time     Name
    1 2015-06-15 14:32:18 Hello1.nprf
    2 2015-06-26 18:39:57 QDTest1.nprf
    3 2015-06-24 22:00:35 QETest1.nprf
    4 2015-06-30 14:32:42 Studio.nprf
    5 2015-07-02 15:02:32 Test.nprf
 
Number of nprf resources in library PRFDATA: 5

Including Profiler Input from Natural Text Objects

The Profiler can read input data from a Natural text object. The syntax of the data in the Natural text object is the same as for the primary command input data set CMSYNIN (see Syntax and Keywords).

Start of instruction setTo include Profiler input data from a Natural text object

The data in the Natural text object is added to the Profiler input data in the line after the INCLUDE keyword. The Profiler input data can contain multiple INCLUDE keywords, and the related Natural text objects can also contain INCLUDE keywords. If a Natural text object contains an END-PROFILER keyword, the Profiler utility terminates and any remaining data in the Natural text object(s) is ignored.

The Natural system library SYSPRFLR supplies text object whose names begin with X which can be used as Profiler input. The individual Profiler functions they perform are described in the sources of these objects.

We recommend that you do not modify any objects in the system library SYSPRFLR because they can be overwritten or removed when a new Natural version is installed. Copy the required object(s) to a user library before you edit it.

Examples of INCLUDE

The following example adds the contents of the Natural MYPROF text object from the library MYLIB to the Profiler input data:

INCLUDE-LIB=MYLIB
INCLUDE=MYPROF

The following example adds the content of the Natural text member XCONS from the library SYSPRFLR to the Profiler input data. The object consolidates Profiler event data. Additionally, it terminates the Profiler utility so that no further Profiler input is expected after the INCLUDE keyword.

INCLUDE=XCONS

Event Trace

The Natural Profiler collects detailed information of each Natural event that occurs while a Natural application executes. This data can be viewed in the event trace.

The traces written for Natural code coverage are described in the section Tracing Natural Code Coverage.

The Profiler utility provides the following options to write a Profiler event trace:

  • Write the trace to standard output while the NPRF data is consolidated. In this case, the event trace shows the delta values of the elapsed time and the CPU time instead of event-specific data.

  • Write the trace when reading a Profiler NPRF resource file with the Profiler utility READ function.

Note:
The event trace can also be listed in NaturalONE.

Start of instruction setTo enable the event trace

  • Enter the following subordinate keyword of the Profiler utility CONSOLIDATE function:

    TRACE-EVENT=ON

    Enter the following subordinate keyword of the Profiler utility READ function:

    EVENT=ON

The Profiler event trace contains the following columns:

Column Description
Count Event count.
Time Event time.

Unit: hour:minute:second.microseconds

CPU-Time Session CPU time.

Unit: microseconds

Ev Event type; see Events and Data Collected.
Lev Program level.
Library Program library.
Program Program (Natural object) name.
Line Line number of program statement executed.
CC-Lib Copycode library (if copycode is active).
CC-Name Copycode name (if copycode is active).
Statement Natural statement currently executed.

For technical reasons, there is no one-to-one relationship between a Natural source code statement and the corresponding object code in the cataloged object. Therefore, the statements listed in the Profiler event trace can differ from the statements in the source.

Local-Data Event-specific data like the Adabas database ID (DBID) and file number (FNR).

This data is only displayed for the Profiler utility READ function.

Elapsed (ms) Elapsed time spent processing the event.

Unit: milliseconds

This data is only displayed for the Profiler utility CONSOLIDATE function.
CPU-Delta CPU time spent processing the event.

Unit: milliseconds

Example of an Event Trace

In the following example, the Profiler utility READ function prints the event trace:

FUNCTION=READ               /* Read event data
  EVENT=ON                  /* Write event trace

The event trace is written to standard output:

Count Time              CPU-Time (ms) Ev Lev Library  Program  Line CC-Lib   CC-Name  Statement  Local-Data
    0 17:38:17.200951          42.324 MP 003 SYSPRFLR PRBINIT  8370                   Call       Monitor pause requested
    0 17:38:17.204508          43.471 MP 003 SYSPRFLR PRBSTART 1760                   Call       Start of block filter
   11 17:38:17.218379          48.874 DB 000                   0000                              00010/00032 S1
   12 17:38:17.218941          48.897 DA 000                   0000                              00010/00032 S1   Rsp: 0
   13 17:38:17.218944          48.910 PL 000                   0000                              Execute PRFDEMO/XPROF
   14 17:38:17.218945          48.916 PS 001 PRFDEMO  XPROF    0000                   PgmStart   00010/00032 Type: P
   15 17:38:17.218956          48.979 IB 001 PRFDEMO  XPROF    0300                   Input      Out: 133 In: 0
   16 17:38:17.219235          49.046 IA 001 PRFDEMO  XPROF    0300                   Input      Out: 133 In: 80
   17 17:38:17.219258          49.182 DB 001 PRFDEMO  XPROF    0370                   Callnat    00010/00032 S1
   18 17:38:17.220426          49.211 DA 001 PRFDEMO  XPROF    0370                   Callnat    00010/00032 S1   Rsp: 0
   19 17:38:17.220427          49.216 DB 001 PRFDEMO  XPROF    0370                   Callnat    00010/00032 S1
   ...

Tracing Natural Code Coverage

When the coverage resource is read with the Profiler utility READ function, the coverage data can be traced with the internal data trace.

Start of instruction setTo enable tracing for code coverage

  • Enable the internal trace by specifying the following subordinate keyword of the Profiler utility READ function:

    TRACE=9

The table below describes the properties listed in the trace:

Property Description
Count The event count.
Ev The event type.

See Events and Data Collected.

Library The name of the Natural library that contains the program/object.
Program/Object The name of the Natural program/object.
Ty The object type such as P for program.
CC-Lib The name of the Natural library that contains the copycode (if copycode is active).
CC-Name The name of the copycode.
Line The source line number.
CC-ID The copycode ID.

It uniquely identifies the copycode instance in the GP. The program gets the copycode ID 0.

Par-CC For copycode only.

The parent copycode ID which is the copycode ID of the object/copycode that includes the current copycode.

FirstS The ID of the first statement of the object or copycode.
Stmts The total number of executable statements in the object whereby all INCLUDE statements are resolved.
Item The item ID of the statement.

It uniquely identifies the statement in the resource file.

Cover The coverage flag (0 or 1) of the statement.

When the GP is read, all flags are initialized with 0. Whenever a statement is executed, the flag is set to 1.

Internal Trace

The Profiler internal trace writes Profiler messages such as errors or warnings.

The internal trace can be activated for the following:

  • The Profiler data processing functions. The data is written to standard output.

Start of instruction setTo activate the internal trace for the Profiler data processing functions

  • Enter the following Profiler keyword:

    TRACE=n

    where n is the trace level (see Trace Levels).

    Notes:

    1. By default (if TRACE is not specified), Trace Level 2 (warnings) is used.
    2. The trace is activated as soon as the TRACE keyword is specified. It is therefore recommended to specify the TRACE keyword as soon as possible.
    3. If you execute the Profiler utility multiple times in the job, you need to specify the TRACE keyword with each execution.

Trace Levels

The trace levels used by the Profiler trace and monitor sessions and by the Profiler data processing functions are listed in the following table. In general, a higher trace level also contains the information of the lower trace levels. For example, if you select Trace Level 3 (statistics), error messages and warnings are also logged.

We recommend that you use at least Trace Level 2 (warnings) so that error messages and warnings are logged.

Trace Level Name Description
0 No trace Profiler internal trace is deactivated.
1 Error Log error messages.
2 Warning Log warnings.
3 Statistics

Data consolidation: Print the profiler statistics including the consolidation statistics.

4 Function Log messages for used Profiler utility keywords (FUNCTION, FILTER, etc.).
5 Block Print the statistics of each data block written to the Profiler resource file.
6 Details Log detailed information.
7   Not used.
8   Not used.
9 Data Trace the coverage resource data when reading an NCVF coverage resource file.
10 Internal Internal usage.

Example

In the following example, the Profiler internal trace is set to 4 (function):

* Set Profiler internal trace
TRACE=4                     /* Trace level

Profiler Statistics

In addition to event data, the Profiler collects statistical data which is written to the Profiler resource file.

The Profiler utility provides the following options to write and view Profiler statistics:

  • Write the statistics to standard output while the data is consolidated.

  • Write the statistics when reading a Profiler resource file with the Profiler utility READ function.

  • View the statistics with the Natural Profiler MashApp.

To write Profiler statistics, perform one of the following steps

  • Enter the following keyword before you start the Profiler utility CONSOLIDATE function:

    TRACE=3

    or a higher trace level (see Trace Levels).

  • Enter the following subordinate keyword of the Profiler utility READ function:

    STATISTICS=ON

The Profiler statistical data is displayed in categories combining properties of a similar type. The following categories are available:

Note:
The properties listed in the following section are the properties provided by the Profiler in all environments. The Profiler statistics contain only the properties that are relevant for the current run. Therefore, not all of the properties listed in the section are displayed in every case.

General Information

Display environment and Natural Profiler related information.

Property Description
Machine class The name of the machine class on which the Natural application is running.
Environment The environment in which the Natural application is running, such as NaturalONE, batch or RPC.
Codepage The code page used while the Natural application was monitored.
User The ID of the user running the application (value of *USER).
Profiler version The internal version of the Profiler.

NaturalONE environment: The version of the Profiler on the server.

Profiler revision The internal revision of the Profiler.
Profiler revision date The date and time when the Profiler revision was created.
Profiler client version NaturalONE environment: The version of the Profiler client.
Profiler trace library NaturalONE environment: The name of the Natural library containing the Profiler internal trace and the Profiler event trace.
Profiler trace level The level of the Profiler internal trace.
Profiler trace member NaturalONE environment: The name of the Natural text object containing the Profiler internal trace.
Profiler event trace Indicates whether the Profiler event trace was activated (ON/OFF).
Profiler event trace member NaturalONE environment: The name of the Natural text object containing the Profiler event trace.
Utility trace level NaturalONE environment: The Natural utilities trace level.

Profiler Resource File

Display Profiler resource file related information.

Property Unit Description
Resource name   The name of the Natural Profiler resource file.
Resource type   The type of the Natural Profiler resource file: Natural Profiler resource file (NPRF), Natural Profiler resource consolidated (NPRC) or Natural code coverage file (NCVF).
Resource short name   Mainframe: The short name of the Natural Profiler resource file.
Resource library   The name of the Natural library containing the Natural Profiler resource file.
Resource DBID   The database ID of the Natural library containing the Natural Profiler resource file.
Resource FNR   The file number of the Natural library containing the Natural Profiler resource file.
Resource allocation date yyyy-mm-dd hh:ii:ss.t The date and time when the Natural Profiler resource file was allocated.
Resource size bytes The size of the Natural Profiler resource file. It comprises the resource headers, the event data and the properties. The resource size is calculated regardless whether the resource is allocated or not.
Resource block size bytes The maximum size of a resource block. A resource block consists of a resource block header and a data block.
Resource version   The version of the Natural Profiler resource layout.

Monitor Session

Display statistics of the Profiler monitor session.

Property Unit Description
Monitor start time yyyy-mm-dd hh:ii:ss.t The date and time when the monitor session started.
Monitor end time yyyy-mm-dd hh:ii:ss.t The date and time when the monitor session ended.
Monitor elapsed time sec The total elapsed time consumed by the monitor session.

Trace Session

Display statistics of the Profiler trace session. The Profiler trace session includes also the application execution.

Property Unit Description
First library   The first library monitored. The libraries SYSTEM, SYSLIB* and SYSPRF* are ignored.
First program   The first program monitored.
Highest level   Highest level number of the Natural objects monitored.
Trace start time hh:ii:ss.microsec The start time of the tracing. With NaturalONE this is the time of the SI (session initialization) event. In batch, the session is already initialized when the monitoring starts. Therefore, the start time is the time of the first event (usually a Monitor Pause event).
Trace end time hh:ii:ss.microsec The end time of the tracing. This is in general the time of the ST (session termination) event.
Trace elapsed time sec The elapsed time consumed by the trace session from the start time to the end time.
Application CPU time ms The total CPU time consumed by the application.
Monitor CPU time ms The total CPU time consumed by the Natural data collector. This time is not measured by the Natural UNIX or Windows server.
Total CPU time ms The total CPU time consumed by the trace session. It is the sum of the application CPU time and the monitor CPU time.
Sampling interval microsec The sampling interval time (CPU time in microseconds). A value of zero (0) means that no sampling was active.
Data pool empty   The number of Profiler read requests which found the Profiler data pool empty (and a session active).
Data pool empty after full   The number of Profiler read requests which found the Profiler data pool empty although it was full before. If this counter is greater than 0, the Profiler data pool is too small which leads to a poor performance.
Data pool overflow   The number of Profiler data pool overflows (with data lost). Data pool overflows should no longer happen. This property is only maintained for backward compatibility with previous versions of Natural.
No session active   The number of read requests which found the Profiler data pool empty and no trace session active. This can only happen for Profiler read requests submitted before the session initialization or after the session termination.

Data Processing

Display statistics of the data processing, compression and transfer.

Property Unit Description
Number of events   The total number of events.
Highest event number   The highest event number as given by the Natural data collector. Note that the Natural data collector counts only non-statement events when called from NaturalONE. In batch it depends on the statement filter whether statement events are counted or not.
Number of data blocks   The number of event data blocks send to NaturalONE or written to the resource.
Utility buffer size bytes The size of the utility buffer used for the data transfer from the server to NaturalONE. In general, the buffer contains the header information and function-specific data.
Data block size bytes The maximum amount of event data which can be transferred from the server to NaturalONE in one call. The same data block size is used for storing the event data in the resource file.
RDC data length bytes The total size of the data received from the Natural Data Collector.
Uncompressed data length bytes The total size of the Profiler data in uncompressed format.
Compressed data length bytes The total size of the compressed data as send to NaturalONE or written to the Profiler resource file.
Identical bytes trimmed left   The number of identical bytes trimmed left at the forward data compression.
Blanks trimmed right   The number of blanks trimmed right at the backward data compression.
Compression header length bytes The total size of the compression headers saved with each compressed event record.
Compression rate percent The percentage of the data reduction by the compression. The higher the compression rate, the less data has to be transferred or saved. The formula of the compression rate is described below.
Events/block   The average number of events contained in one event data block.
Bytes/event   The average length in bytes of a compressed event data record. This property is not available for consolidated or coverage data.

The compression rate is calculated by the following formula:

CompressionRate := 100 ×

BytesTrimmedLeft + BytesTrimmedRight - CompressionHeaderLength
UncompressedDataLength

Event Type Statistics

Display statistics of the event types.

Property Description
Unknown event The number of unknown events.
Session initialization The number of Session Initialization events.
Session termination The number of Session Termination events.
Program load The number of Program Load events.
Program start The number of Program Start events.
Program termination The number of Program Termination events.
Program resume The number of Program Resume events.
Program information The number of Program Information events.
Before database call The number of Before Database Call events.
After database call The number of After Database Call events.
Before terminal I/O The number of Before Terminal I/O events.
After terminal I/O The number of After Terminal I/O events.
Before external program call The number of Before External Program Call events.
After external program call The number of After External Program Call events.
Runtime error The number of Runtime Error events.
Natural statement The number of Natural Statement events.
Outbound RPC message The number of Outbound RPC Message events.
Inbound RPC message The number of Inbound RPC Message events.
Start RPC request execution The number of Start of RPC Request Execution events.
RPC Wait for Client The number of RPC Wait for Client events.
User trace call The number of User-Defined Events.
Monitor pause The number of Monitor Pause events.
Monitor filter The number of monitor filter events. Filter events are not recorded.

Monitor Pause Statistics

Display statistics of the types of Monitor Pause events.

Property Description
Pause - unknown type The number of Monitor Pause events with unknown pause type.
Pause - requested The number of requested Monitor Pause events.
Pause - start of block filter The number of Monitor Pause events caused by a start of a block filter (library, program, line, FNAT, event count or time filter).
Pause - data pool full The number of Monitor Pause events caused by a data pool full situation.
Pause - data pool overflow The number of Monitor Pause events caused by a data pool overflow situation.

Data Consolidation

Display statistics of the data consolidation.

Property Unit Description
Consolidation   Indicates whether the Profiler data is consolidated (ON/OFF). The consolidation aggregates similar events into one consolidation record.
Consolidation records   The total number of consolidation records. In general, a consolidation record comprises multiple events.
Consolidation elapsed time sec The elapsed time in seconds required for the data consolidation with the Profiler utility CONSOLIDATE function.
Consolidation factor   The average number of events combined into one consolidation record. The higher the consolidation factor, the better the consolidation.
ConsolidationFactor := NumberOfEvents / ConsolidationRecords
Consolidation records/block   The average number of consolidation records contained in one data block.
Bytes/consolidation record   The average length in bytes of a compressed consolidation record.
Consolidate I/O time   Indicates whether I/O and Natural RPC client time are included in the consolidated data.

Coverage

Display statistics of Natural code coverage.

Note:
Natural code coverage statistics are collected on the mainframe only.

Property Description
Coverage Indicates whether Natural code coverage is performed (ON/OFF).
Missed statements recorded Indicates whether missed statements are recorded (ON/OFF).
Coverage records The total number of coverage records. These are program information and Natural statement records.
Program information records The number of program information records written to the resource file. Each program information record contains program and copycode-related information.
Coverage records/block The average number of coverage records contained in one data block.
Bytes/coverage record The average length in bytes of a compressed coverage record.
Programs covered The number of covered programs.
Programs NOC-ed The number of covered programs compiled with the Natural Optimizer Compiler.
Statement coverage The percentage of statements of all accessed programs that have been covered by the application.
Statements covered The number of covered (executed) statements.
Statements total The total number of executable statements of all programs accessed.

Transaction

Display statistics of executed transactions.

Note:
Transaction statistics are only available if Profiler data has been consolidated with the CONSOLIDATE function set to TRANSACTION=ON.

Property Unit Description
Transaction   Indicates whether transaction identifiers are added to the consolidated records (ON/OFF).

Transaction identifiers are required to evaluate the response time for transactions.

Number of transactions   The total number of processed transactions. A transaction is the code executed between two consecutive terminal I/O operations.
Total response time sec The total elapsed time used to process all transactions.
Average response time sec The average elapsed time used per transaction.
Max response time sec The maximum (highest) elapsed time used to process transactions.
ID max response time   The transaction identifier of the transaction with the highest elapsed time.

In addition to the transaction identifier, the statisitcs indicates the program name, copycode name (if any) and program line from where the terminal I/O operation was issued.

For more information on evaluating transactions, see Transaction Summary.