2.1 Service Model Definition

A service model contains definitions of objects that represent dimensions, metrics, KPIs, and alarm thresholds. The service model also describes these objects, e g the metrics and dimensions that are required to calculate a KPI. 

Service model objects and dependencies

The metric and dimension objects are mapped to specific fields in the KDR input. The figures in the example below illustrate how the input data is mapped to a KDR and finally to dimensions and a metric.

Example - Mapping objects to KDR input

The UDR types below have a startTime field that can be used for triggering start and closing of period, i e timestamp field of the KDR is populated with this value. If this type of field does not exist, you can generate a timestamp from APL.

The UDRs RecA and RecB have a different set of fields but it is possible to define dimensions and metrics for the set fields that are available in each type. For instance, a metric can be defined so that it is calculated based on valueX for type 1 and valueY for type 2. You may use any string value as a type identifier. In this example the recordType field is used to identify the type.

Ultra configuration

The KDRs are populated with the values from the collected UDRs. The keys in the value field of the KDR (hereafter also referred to as "fields") can be selected arbitrarily but have to be unique within the KDR. These fields will be referenced in the metric and dimension definitions of the service model.

At this point it would have been possible to treat both UDR types, RecA and RecB, as a single type. In this case you would assign the same field names to both records. For instance, myvalue instead of valueX or valueY.

The fields that will be used for metric calculations must be numerical types, e g int, long, float, double etc.

APL configuration

The service model has two dimensions, Region and Site. There are two references for each of the dimensions, one for the respective types. For type 1, the model references the field region to retrieve the instantiated name of Region. For type 2, it references the field named district. It is assumed here that these will serve an identical purpose even though the original UDRs have distinct formats.

The service model has a simple structure under the tree object that indicates that Region is the parent dimension to Site. This tree has a single root node, tree1, but you may add multiple root nodes. For instance, if a site may span multiple regions, you may want to add a second tree where the hierarchal order is reversed.

The service model has one metric that calculates an average value. Similar to the dimension, there are references for each type in the expression (expr). The expression only contains one field name, which will return its actual value as a floating-point number (double). You may perform more complex calculations using functions, operators, and a combination of fields. For further information, see 2.3.3 metric.

Finally the the dimensions, metric, and the tree are combined to define two KPIs. When you apply this model in KPI Management, the output in each period will be the Average metric for the two dimensions, Region and Site. The length of the periods is specified by windowSize, which will have the same unit as the input value. For instance, if the value in the timestamp field of the KDR has the unit seconds, the period length will be 60 seconds.

Service model

Object Types Overview

These are the main object types in the service model:

Object TypeDescription
dimension

The dimension objects represent values that are extracted from KDR UDRs and are used for grouping in KPI calculations. For instance, if the input data contains a field that represents a geographic region, it can be mapped to an object instance named "Region".

Example - JSON Representation

"dimension": {
     "Region": {
       "kdr_record_type_a": "region_name"
     }
 }

For further information about the dimension object type, see 2.3.1 dimension.

tree

The tree objects contain nodes that describe the hierarchical structure of the dimensions.

The name of a tree object constitutes the root node of a tree. The root node may have one or more child nodes, e g "Region". A child node in turn may have its own child nodes, e g "City" or "Site", and so on.

Example - JSON Representation

"tree": { 
	"tree1": { 
		"Region": { 
			"Site": {} 
		} 
	} 
} 

For further information about the tree object type, see 2.3.2 tree.

metric

The metric objects represent values that are extracted from KDR UDRs and aggregated according to the tree structure in the model. Expressions are applied on the various fields in the UDRs to calculate a value, e g a sum, average, or min/max value.

Example - JSON Representation

"metric": { 
	"AvgDuration": { 
		"fun": "avg", 
        "expr": { 
          "kdr_record_type_a": "field2-field1", 
          "kdr_record_type_b": "field3" 
        } 
	}     
}

For further information about the metric object type, see 2.3.3 metric.

threshold

The threshold objects contain a set of level objects that define limits for the KPIs. When a limit is exceeded within a defined period, a threshold object and a level object are referenced in the KPIOutput UDRs. You can define the limit values for a threshold object in ascending or descending order.

Example - JSON Representation

 "threshold": { 
	"Region.AD": { 
		"orderDescending": true, 
		"levels": { 
			"1": { 
            "alarmDescription": "", 
            "value": 200 
          }, 
          "2": { 
            "alarmDescription": "", 
            "value": 100 
          } 
        } 
	} 
} 

For further information about the threshold object type, see 2.3.4 threshold.

kpi

The kpi objects describe how metrics are linked to dimensions and threshold levels.
You may configure kpi objects to perform additional calculations based on metrics, e g ratios or sums of ratios.

Example - JSON Representation

"kpi": {
     "Region.AD": {
       "node": [
         "tree1",
         "Region"
       ],
       "windowSize": 60,
       "threshold": "Region.AD",
       "expr": "AvgDuration"
     }
 }

For further information about the kpi object type, see 2.3.5 kpi.