From 8c40e302a22efdc64ac5fbfbb260c8f7a89daa18 Mon Sep 17 00:00:00 2001 From: Erik Jaegervall Date: Fri, 13 Dec 2024 09:52:22 +0100 Subject: [PATCH] Clarify VSS expectations on read/write I ended up in a discussion of what "doing a read" in VSS means. In short, as of today that we say that a read returns actual value. This PR suggests to change the wording somewhat, so that a read unless otherwise specified shall return the actual value. I.e. it is not forbidden by VSS (project) to have a read-function that returns the desired value instead, but then that must be clearly specified in the corresponding implementation specification. Signed-off-by: Erik Jaegervall --- .../rule_set/data_entry/sensor_actuator.md | 19 ++++++++++++++++--- 1 file changed, 16 insertions(+), 3 deletions(-) diff --git a/docs-gen/content/rule_set/data_entry/sensor_actuator.md b/docs-gen/content/rule_set/data_entry/sensor_actuator.md index be318d25..1e6ee87b 100644 --- a/docs-gen/content/rule_set/data_entry/sensor_actuator.md +++ b/docs-gen/content/rule_set/data_entry/sensor_actuator.md @@ -4,13 +4,24 @@ date: 2019-08-04T12:37:03+02:00 weight: 30 --- -Sensors are signals to read values of properties in a vehicle. Values of sensors typically change over time. Reading a sensor shall return the current actual value of the related property, e.g. the current speed or the current position of the seat. +# Property Types Overview -Actuators are used to control the desired value of a property. Some properties in a vehicle cannot change instantly. A typical example is position of a seat or a window. Reading a value of an actuator shall return the current actual value, e.g. the current position of the seat, rather than the wanted/desired position. A typical example could be if someone wants to change the position of a seat from 0 to 100. This can be changed by setting the corresponding actuator to 100. If the actuator is read directly after the set request it will still return 0 as it might take some seconds before the seat reaches the wanted position of 100. If the seat by some reason is blocked or cannot be moved due to safety reasons it might never reach the wanted position. It is up to the vehicle to decide how long time it shall try to reach the desired value and what to do if it needs to give up. +Sensors are properties that from a VSS-perspective are read-only. Values of sensors typically change over time. +Reading a sensor shall return the actual value of the related property, e.g. the current speed or the current position of the seat. + +Actuators in VSS can be used to represent both the actual value and the desired value of a property. +Some properties like position of a seat or a window in a vehicle cannot change instantly, which means that current and actual value may differ. +Unless otherwise specified it is assumed that APIs implementing access to VSS data shall return actual value for read/subscribe-operations, +and update the desired value for write-operations. + +A typical example could be if someone wants to change the position of a seat from 0 to 100. This can be changed by setting the corresponding actuator to 100. +If the actuator is read directly after the set request it will still return 0 as it might take some seconds before the seat reaches the wanted position of 100. +If the seat by some reason is blocked or cannot be moved due to safety reasons it might never reach the wanted position. +It is up to the vehicle to decide how long time it shall try to reach the desired value and what to do if it needs to give up. Attributes are signals that have a default value, specified by its ```default``` member. -The standard Vehicle Signal Specification does not include default values for all attributes. +The standard Vehicle Signal Specification catalog does not include default values for all attributes. If a default value has not been specified then the OEM must define a default value matching the actual vehicle. If the standard defines a default value but it does not fit the actual vehicle, then the OEM must override the standard default value. @@ -20,6 +31,8 @@ The latter can be useful for attribute values that are likely to change during t However, attribute values should typically not change more than once per ignition cycle, or else it should be defined as a sensor instead. +# Data Entry + A data entry for a signal defines its members. A data entry example is given below: