# Signal Mapping Format Specification {#page_signal_mapping_spec}
# Configuration format
The actual mapping of signals is configured using a xml-based configuration format.
## Overview
A mapping configuration file contains a header with meta information about the file, source signal declarations, target signal definitions and transformation definitions. A source signal consists of a name and a signal type. Target signals also consist of a name and a signal type. They define any number of signal element assignments as well as any trigger conditions.
Conceptionally, signal element assignments define how the target signal is assembled while triggers define when the target signal buffer is submitted to the user.
A target signal element can be assigned a constant numeric value or a source signal element. In the later case, a transformation can be used to alter the source signal element value during assignment. For details see \ref subsec_features_types. Trigger conditions are optional, since it is always possible to actively get the current target signal buffer. For now, only periodic triggers can be defined, using a period and a unit of time.
## Specification
This specification contains the following parts:
- Header
- Sources
- Targets
- Transformations
These sections will be described in the following paragraphs, see the [XSD specification](../mapping_configuration.xsd) for more details.
### Header
The header section contains meta information about the document and version information.
It is similar to the header informations in the DDL Definition File Format.
|Tag|Type|Required|Description|
|--- |--- |--- |--- |
|language_version|Float|mandatory|Version number of the mapping format|
|author|String|mandatory|Author|
|date_creation|Date|mandatory|Creation date|
|date_change|Date|mandatory|Last modification date|
|description|Text|mandatory|Short description|
### Sources
This section defines the source signals that can be used in assignments to any target signal elements(s).
The tag `<source>` supports the following attributes:
|Name|Type|Required|Description|
|--- |--- |--- |--- |
|name|String|mandatory|Name of the signal|
|type|String|mandatory|DDL structured type of the signal|
### Targets
This section contains definitions of target signals, assignement to their target elements as well as any trigger definitions.
The tag `<target>` supports the following attributes:
|Name|Type|Required|Description|
|--- |--- |--- |--- |
|name|String|mandatory|Name of the signal|
|type|String|mandatory|DDL structured type of the signal|
The tag `<assignment>` supports the following attributes:
|Name|Type|Required|Description|
|--- |--- |--- |--- |
|to|String|mandatory|Name of the target signal element to be assign|
|constant|String|optional*|Float value which will assigned during initialisation|
|function|String|optional*|Macro to assign|
|from|String|optional*|Source signal or source signal element to assign|
|transformation|String|optional|Transformation to apply to the source element|
__*__: The attributes _constant_, _function_ and _from_ are mutually exclusive but one of them is required.
The attribute _transformation_ can only be applied when the attribute _from_ is defined.
The attribute _function_ can have the values:
|Function|Parameter|Description|
|--- |--- |--- |
|simulation_time()|None|Evaluates to the current simulation time|
|trigger_counter()|None|Trigger counter, incremented whenever a trigger for the target fires|
|trigger_counter()|Positive numeric value, modulo parameter|Trigger counter with wrap-around|
|received()|Name of the source signal|Received indicator, evaluates to true if the source signal has been received|
The tag `<trigger>` supports the following attributes:
|Name|Type|Required|Description|
|--- |--- |--- |--- |
|type|String|mandatory|Trigger type|
|period|String|optional|Float value defining the length of the period|
|unit|String|optional|unit to interpret the given _period_|
|variable|String|optional|For _signal_ triggers: name of the source signal, for _data triggers: name of the source signal element|
|operator|String|optional|Operator used for data triggers: less_than, greater_than, less_than_equal, greater_than_equal, equal or not_equal|
|value|String|optional|Float value to compare with the source element|
The attribute _type_ has three acceptable values:
- _periodic_
- _data_
- _signal_
For the _periodic_ Trigger type, the attributes _period_ and _unit_ are mandatory.
For the _data_ Trigger type, the attributes _variable_, _operator_ and _value_ are mandatory.
For the _signal_ Trigger type, the attribute _variable_ is mandatory.
### Transformations
This section contains definitions of transformations that can be used in assignements.
For the moment the only transformations available are polynomial tranformations and enum to enum transformations.
The tag `<polynomial>` supports the following attributes:
|Name|Type|Required|Description|
|--- |--- |--- |--- |
|name|String|mandatory|Name of the transformation|
|a|String|optional|parameter of the polynom for X^0|
|b|String|optional|parameter of the polynom for X^1|
|c|String|optional|parameter of the polynom for X^2|
|d|String|optional|parameter of the polynom for X^3|
|e|String|optional|parameter of the polynom for X^4|
The tag `<enum_table>` supports the following attributes:
|Name|Type|Required|Description|
|--- |--- |--- |--- |
|name|String|mandatory|Name of the transformation|
|from|String|mandatory|Enumeration type used as transformation source|
|to|String|mandatory|Enumeration type used as transformation target|
|default|String|mandatory|Default value used when no conversion is defined. It must be an element of the target enumeration|
The tag `<conversion>` supports the following attributes:
|Name|Type|Required|Description|
|--- |--- |--- |--- |
|from|String|mandatory|Element from the enumeration type used as transformation source|
|to|String|mandatory|Element from the enumeration type used as transformation target|
## Example
The following example shows the mapping of the target signals `LightSource` and `Object`.
`LightSource` elements are mapped from two source signals, `LightOrientation` and `LightPos`, as well as some constants.
Two of its assignments are also transformed during mapping. The entire target is triggered by a periodic trigger with a period of 5s, and when LightPos is received and LightPos.f64X is lesser than 2.
`Object` element is an enumeration, mapped with transformation from `SourceObject`.
The Enumeration Type _tObjectType_ is mapped in an obsolete Enumeration created for the example.
This Target is trigger when `LightOrientation` is received.
````xml
1.00AUDI Electronic Ventures GmbH2016-Jun-082016-Jun-08Example mapping configuration
````
# Features
## Constants and Macros
A target signal element can be assigned a constant numeric value. This value will be parsed as a floating point number and casted to the target element type.
A target signal element can also be assigned the simulation time, a trigger counter or a received flag.
**Note:**
Constants and Macros can only be used to initialize scalar as well as arrays of scalar elements
Any unassigned target elements will be assigned the default value configured in the DDL definition of the target signal type
## Transformations
Transformations can be used to alter the value of an assignment during runtime.
Polynomial and enum to enum transformations are supported.
Polynomial transformations use the following polynomial to transform the assignments:
````
value = a*value^0 + b*value^1 + c*value^2 + d*value^3 + e*value^4
````
Any undefined coefficients are set to 0.
**Note:**
Transformations are only supported for scalar as well as arrays of scalar elements
## Supported types and cross-type assignments
Assignments from one type to another are supported in the following way
Source | Target | Specification
------------- | ------------- | -------------
Constant | Scalar | Datatype conversion using standard C++ casting methods
Simulation time | Scalar | Datatype conversion using standard C++ casting methods
Trigger counter | Scalar | Datatype conversion using standard C++ casting methods
Received Flag | Scalar | Only for boolean
Scalar | Scalar | Datatype conversion using standard C++ casting methods. Transformations allowed
Array | Array | Only for arrays of same size. Datatype conversion using standard C++ casting methods. Transformations allowed
Structure | Structure | Only for structures of same type
Array | Array | Only for arrays of same size and structures of same type
Enum | Enum | Datatype conversion to the underlying numerical datatype using standard C++ casting methods
Array | Array | Only for arrays of same size. Datatype conversion using standard C++ casting methods.
Scalar datatypes are enumerations, `tBool`, `tChar`, `tUInt8`, `tInt8`, `tUInt16`, `tInt16`, `tUInt32`, `tInt32`, `tUInt64`, `tInt64`, `tFloat32` and `tFloat64`.
Array and structure elements can be used separately in assignments, for example:
````xml
````
**Note:**
A target element can only be assigned once. For instance, if one element in a substructure is already assigned, the whole substructure can not be assigned and reciprocally.
Target and source signals may only use structured types