The ResultManagementType provides mechanism to access results generated by the underlying system. Results can be managed in a local result store of the Server. Methods and Objects with Variables as well as Events and external file stores can be used to provide the results to the Client. The ObjectType is formally defined in Table 45.

Table 45 - ResultManagementType Definiton

Attribute

Value

BrowseName

ResultManagementType

IsAbstract

False

References

Node Class

BrowseName

DataType

TypeDefinition

Other

Subtype of the 0:BaseObjectType defined in OPC 10000-5

0:HasProperty

Variable

0:DefaultInstanceBrowseName

0:QualifiedName

PropertyType

0:HasComponent

Method

GetResultById

O

0:HasComponent

Method

GetLatestResult

O

0:HasComponent

Method

GetResultListFiltered

O

0:HasComponent

Method

ReleaseResultHandle

O

0:HasComponent

Object

Results

0:FolderType

O

0:GeneratesEvent

ObjectType

ResultReadyEventType

The components of the ResultManagementType have additional subcomponents which are defined in Table 46.

Table 46 - ResultManagementType Additional Subcomponents

Source Path

Reference

NodeClass

BrowseName

DataType

TypeDefinition

Others

Results

0:HasComponent

Variable

<ResultVariable>

ResultDataType

ResultType

OP

The component Variables of the ResultManagementType have additional Attributes defined in Table 47.

Table 47 - ResultManagementType Attribute values for child nodes

BrowsePath

Value Attribute

Description Attribute

0:DefaultInstanceBrowseName

ResultManagement

The default BrowseName for instances of the type.

Note:

  • Server can return the standard OPC UA error codes as part of the status of the method call execution. Example: Method call not implemented, No data available, etc.

This method is used to retrieve a result by identifier from a given system. Depending on the design of the system, the client may be informed by events of ResultReadyEventType that a new result is available. Then, the client might fetch this result using the information provided by events of ResultReadyEventType.

Since the ResultId is supposed to be system-wide unique, this method shall return only a single result. Since there may be additional result content to be retrieved, the server should keep result data available, resources permitting, until the client releases the handle using ReleaseResultHandle method. However, the client cannot rely on the data to remain available until then.

Signature

GetResultById (

[in]GuidResultId,

[in]Int32ResourceTimeout,

[out]UInt32ResultHandle,

[out]ResultDataTypeResult,

[out]Int32Error)

Table 48 - GetResultById Method Arguments

Argument

Description

ResultId

System-wide unique identifier for the result.

ResourceTimeout

With this argument the client can give a hint to the server how long it will need access to the result data.

A value > 0 indicates an estimated maximum time for processing the data in milliseconds.

A value = 0 indicates that the client will not need anything besides the data returned by the method call.

A value < 0 indicates that the client cannot give an estimate.

The client cannot rely on the data being available during the indicated time period. The argument is merely a hint allowing the server to optimize its resource management.

ResultHandle

The server shall return to each client requesting result data a system-wide unique handle identifying the result set / client combination. This handle should be used by the client to indicate to the server that the result data is no longer needed, allowing the server to optimize its resource handling.

Result

The result including metadata.

Error

0 – OK

Values > 0 are reserved for errors defined by this and future standards.

Values < 0 shall be used for application-specific errors.

Note: If the error != 0, the server is allowed to return NULL values for Result and 0 for ResultHandle but server might still return some data which is application specific.

Table 49 - GetResultById Method AddressSpace definition

Attribute

Value

BrowseName

GetResultById

References

NodeClass

BrowseName

DataType

TypeDefinition

Others

HasProperty

Variable

InputArguments

Argument[]

PropertyType

M

HasProperty

Variable

OutputArguments

Argument[]

PropertyType

M

This method is used to retrieve the latest result available in a given system.

Signature

GetLatestResult (

[in]Int32ResourceTimeout,

[out]UInt32ResultHandle,

[out]ResultDataTypeResult,

[out]Int32Error)

Table 50 - GetLatestResult Method Arguments

Argument

Description

ResourceTimeout

With this argument the client can give a hint to the server how long it will need access to the result data.

A value > 0 indicates an estimated maximum time for processing the data in milliseconds.

A value = 0 indicates that the client will not need anything besides the data returned by the method call.

A value < 0 indicates that the client cannot give an estimate.

The client cannot rely on the data being available during the indicated time period. The argument is merely a hint allowing the server to optimize its resource management.

ResultHandle

The server shall return to each client requesting result data a system-wide unique handle identifying the result set / client combination. This handle should be used by the client to indicate to the server that the result data is no longer needed, allowing the server to optimize its resource handling.

Result

The result including metadata.

Error

0 – OK

Values > 0 are reserved for errors defined by this and future standards.

Values < 0 shall be used for application-specific errors.

Note: If the error != 0, the server is allowed to return NULL values for Result and 0 for ResultHandle but server might still return some data which is application specific.

Table 51 - GetLatestResult Method AddressSpace definition

Attribute

Value

BrowseName

GetLatestResult

References

NodeClass

BrowseName

DataType

TypeDefinition

Others

HasProperty

Variable

InputArguments

Argument[]

PropertyType

M

HasProperty

Variable

OutputArguments

Argument[]

PropertyType

M

This method is used to get a list of results matching certain filter criteria.

Signature

GetResultListFiltered (

[in]UtcTimeFromTime,

[in]UtcTimeToTime,

[in]ResultEvaluationResultEvaluation,

[in]Int32[]SequenceNumbers,

[in]UInt32MaxResults,

[in]UInt32StartIndex,

[in]GuidReporterAssetId,

[in]GuidGeneratorAssetId,

[in]BooleanIncludeStepResults,

[in]BooleanIncludeErrors,

[in]BooleanIncludeTraces,

[in]Int32ResourceTimeout,

[out]BooleanIsComplete,

[out]UInt32ResultCount,

[out]UInt32TotalAvailableResults,

[out]UInt32ResultHandle,

[out]ResultDataType[]ResultList,

[out]Int32Error)

Table 52 - GetResultListFiltered Method Arguments

Argument

Description

FromTime

If not null, results from the given FromTime are returned in the ResultList.

Any set of results whose StartTime is greater or equal to FromTime will be returned in the ResultList.

ToTime

If not null, results till the given toTime are returned in the ResultList.

Any set of results whose EndTime is less than or equal to ToTime will be returned in the ResultList.

ResultEvaluation

Input to return results based on OK or NOT_OK count. The results based on the evaluation are returned in the ResultList.

SequenceNumbers

If not an empty array, the list of sequence numbers requested from the client.

MaxResults

Maximum number of results to return in one call; by passing 0, the client indicates that it does not put a limit on the number of results.

StartIndex

Shall be 0 on the first call, multiples of MaxResults on subsequent calls to retrieve portions of the entire list, if necessary.

ReporterAssetId

If not null, System wide unique identifier of the asset which reports the results.

GeneratorAssetId

If not null, System wide unique identifier of the asset which generates the results.

IncludeStepResults

A Boolean flag to notify the application to include list of step results in the ResultList. By default, it is set to false.

IncludeErrors

A Boolean flag to notify the application to include list of errors in the ResultList. By default, it is set to false.

IncludeTraces

A Boolean flag to notify the application to include list of traces in the ResultList. By default, it is set to false.

ResourceTimeout

With this argument the client can give a hint to the server how long it will need access to the result data.

A value > 0 indicates an estimated maximum time for processing the data in milliseconds.

A value = 0 indicates that the client will not need anything besides the data returned by the method call.

A value < 0 indicates that the client cannot give an estimate.

The client cannot rely on the data being available during the indicated time period. The argument is merely a hint allowing the server to optimize its resource management.

IsComplete

Indicates whether there are more results in the entire list than retrieved according to StartIndex and ResultCount.

ResultCount

Provides the number of results returned in ResultList in the specific method call.

TotalAvailableResults

This is the total number of results available based on the filtering criteria. This value will be same till the IsComplete is set to true if it is based on filter criteria.

If filter criteria is not provided, then it is the total number of results available in the server.

ResultHandle

The server shall return to each client requesting result data a system-wide unique handle identifying the result set / client combination. This handle should be used by the client to indicate to the server that the result data is no longer needed, allowing the server to optimize its resource handling.

ResultList

List of results matching the filter criteria.

Error

0 – OK

Values > 0 are reserved for errors defined by this and future standards.

Values < 0 shall be used for application-specific errors.

Note: If the error != 0, the server is allowed to return NULL values for ResultList and 0 for ResultHandle but server might still return some data which is application specific.

There are the following cases with the respect to the number of results:

  • The number of results to be returned is larger than MaxResults; the first N calls (N > 0 with N ≤ (number of results) divisor MaxResults), with StartIndex =(N-1)*MaxResults, return IsComplete =FALSE, so the client knows that further calls are necessary. The following call returns IsComplete =TRUE, so the client knows, no further calls are necessary. ResultCount gives the number of valid elements in the ResultList array (on each call, so on the first N calls, this should be MaxResults).

Table 53 - GetResultListFiltered Method AddressSpace definition

Attribute

Value

BrowseName

GetResultListFiltered

References

NodeClass

BrowseName

DataType

TypeDefinition

Others

HasProperty

Variable

InputArguments

Argument[]

PropertyType

M

HasProperty

Variable

OutputArguments

Argument[]

PropertyType

M

This method is used to inform the server that the client has finished processing a given result set allowing the server to free resources managing this result set. The server should keep the data of the result set available for the client until the ReleaseResultHandle method is called or until a timeout given by the client has expired.

However, the server is free to release the data at any time, depending on its internal resource management, so the client cannot rely on the data being available. ReleaseResultHandle is merely a hint allowing the server to optimize its internal resource management. For timeout usage see the description.

Note: The ResultHandle is provided as an option to be used by application for flexibility. Applications can choose to use it based on the use case or ignore it.

Signature

ReleaseResultHandle (

[in]UInt32ResultHandle,

[out]Int32Error)

Table 54 - ReleaseResultHandle Method Arguments

Argument

Description

ResultHandle

Handle returned by GetResultById or GetResultListFiltered or GetLatestResult, identifying the result set/client combination.

Error

0 – OK

Values > 0 are reserved for errors defined by this and future standards.

Values < 0 shall be used for application-specific errors.

Table 55 - ReleaseResultHandle Method AddressSpace definition

Attribute

Value

BrowseName

ReleaseResultHandle

References

NodeClass

BrowseName

DataType

TypeDefinition

Others

HasProperty

Variable

InputArguments

Argument[]

PropertyType

M

HasProperty

Variable

OutputArguments

Argument[]

PropertyType

M

This is an instance of FolderType and is used to organize multiple available results in the underlying system which the server decides to expose in the Address Space. It may contain no results if the server does not expose results in the Address Space at all or if no available result matches the criteria for exposure in the Address Space.

<ResultVariable> is an optional placeholder for ResultType instances.

Note: The organization of the <ResultVariable> instances in the Results folder instance is application specific. The semantics and rules are not defined in this version of the specification.