Skip to content

Latest commit

 

History

History
172 lines (109 loc) · 13.4 KB

README.adoc

File metadata and controls

172 lines (109 loc) · 13.4 KB

Digital Twin (uTwin)

The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this document are to be interpreted as described in IETF BCP14 (RFC2119 & RFC8174)

Copyright (c) 2023 General Motors GTO LLC

Licensed to the Apache Software Foundation (ASF) under one
or more contributor license agreements.  See the NOTICE file
distributed with this work for additional information
regarding copyright ownership.  The ASF licenses this file
to you under the Apache License, Version 2.0 (the
"License"); you may not use this file except in compliance
with the License.  You may obtain a copy of the License at

  http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing,
software distributed under the License is distributed on an
"AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
KIND, either express or implied.  See the License for the
specific language governing permissions and limitations
under the License.

SPDX-FileType: DOCUMENTATION
SPDX-FileCopyrightText: 2023 General Motors GTO LLC
SPDX-License-Identifier: Apache-2.0

1. Purpose

In uProtocol, uEs rely on other uEs that expose services, named uServices. These uServices publish information, named events, on Topics, through the uPlatform. These events can be considered to represent updates to the uService state. The collection of last published event of each Topic of a uService therefore represents the current "public state" of the uService (public because some more internal states might exist without being exposed externally).

An event published on a uDevice is propagated to all other uDevices that have at least one uE subscribed to the corresponding Topic, but only to those devices, These events can therefore be stored on the received devices "for free", i.e. without requiring a dedicated transmission. Storing the last event received per-topic, on each uDevice, therefore enables access without re-transmission overhead/cost/latency for uEs running on the same device devices that wish to retrieve the last state of a uService, i.e. the last event published on a Topic. Implementing such storage mechanism essentially implements a digital twin mechanism for uEs in the sense that uE’s last known states are stored in all uDevice that are subscribed to the uService, and accessible by local uE. uTwin figure below provides a visual description of the context.

uTwin
Figure 1. uTwin

A uE requiring information/state from a uService will therefore subscribe to Topics of interest created by that uService. Consequently, once a uE is connected to uPlatform and subscribed to uServices it requires, it will receive any state update (of interest, i.e. to which it subscribed). The unresolved issue is to define a mechanism that enables a uE connecting to uPlatform to receive the "last known state" (published while the uE was not connected to uPlatform) of the uServices it relies on. A uE connects to uPlatform for the following reasons:

  • Executed for the first time after installation

  • Connected to a new uService (e.g. cloud uE connecting to a new vehicle that enrolled to the service provided by the cloud uE)

  • uE restarting for whatever reason (uE crash, ignition off, system in deep sleep)

The mechanism aimed at providing "last known uService state" to uEs requiring it is also known as digital twin. While this mechanism is usually used for replication of a state in remote devices (e.g. IoT device state replicated in Cloud), in our context, we also need a similar mechanism to deliver such last known state to local uEs. Example Last-Known-State Use Cases below illustrates the usefulness of the uTwin:

Table 1. Example Last-Known-State Use Cases
from \ to Vehicle Mobile Cloud

Vehicle

Yes

Yes

Yes

Mobile

Yes

No

Yes

Cloud

Yes

Yes

No

Main justification for the need of digital twin are described below:

  • Device-to-device Twin:

    • To enable remote Apps to access last published state (and received by the device)

    • To remain accessible even if connectivity is lost

  • In-vehicle Twin:

    • To avoid re-sending (re-publishing) data when apps are launched/subscribed

This document suggests approaches to implement a digital twin concept for uProtocol.

Note
The uTwin interface is utwin.proto

2. Proposal

The solution consists in creating a software component, named uTwin, that embodies this automatically created and updated digital twin component. The uTwin component is connected to the communication framework (i.e. the uBus) of each device in charge of dispatching messages.

  • Every publish message that flows through the uBus SHALL be “delivered” to uTwin

the uTwin stores the published message using a primary key to enable local software components to retrieve it. This primary key is the full name of the Topic, hence also including the device name. The fact that the primary key represents a topics ensures that only the last event of a given Topic is stored in the uTwin. The collection of events stored in a uTwin instance of a device, whose keys include a specific device name (e.g. deviceA), represent the digital twin of that device (deviceA in our example).

Examples of events for a vehicle may include tire pressure, window position, gear position but also vehicle mode (driving, parked), and in general any information that is published within the vehicle for the purpose of operating it and activating its features.

So, for example, if a cloud application MyApp subscribes to the tire pressure of a given vehicle (named vehA), then every time vehA publishes a new value for the tire pressure, the event will be delivered to the cloud and to MyApp. The uTwin instance running on the cloud will also receive this information and store it with the primary key including the vehicle name vehA and the topic name TirePressure, so that any other software subsequently wishing to access the tire pressure can simply request it from the cloud uTwin.

uTwin Sequence Diagram below illustrates the overall mechanism, with special focus on the following properties:

  • Implicit (automatically inferred) digital twin model: no need for manual definition of the dig twin model

  • Dynamic model creation, based on events that flow through the distributed communication framework (named uPlatform in the diagram) and storage of device states (represented by the collection of service topics of a device)

  • uTwin of each device received all events flowing through the device, therefore creating a local dig twin accessible by all apps local to this device

  • Only events that must be transferred due to existing subscribers are transmitted, and therefore stored in a remote device (therefore minimizing communication overhead related to utwin management)

uTwin Sequence Diagram
Figure 2. uTwin Sequence Diagram

uTwin brings 2 novelties:

  • It fully automates the manual task of creating the data model of the digital twin

  • It dynamically adapts the content of the digital twin exactly to the data requested by the consumers, therefore optimizing data transmission and storage

It relies on 2 primary mechanisms (that themselves leverage properties of the communication framework):

  • uTwin component being “plugged” into the local bus to collect all events flowing through the communication framework of the device

  • uTwin storing the events using the Topic, which ‘embeds’ the device name, as primary key, so that they can serve as the digital twin model of remote devices when requested to provide the state (i.e. Topic value) of a given device

2.1. uTwin, a distributed cache…​

The Platform itself (which uTwin is part of) is acting as a distributed cache for the state of all devices connected in the network. Each cache (i.e. uTwin) instance only keeps the subset of the overall devices services states that flows through the device during "normal" event routing operations, therefore not generating any communications overhead.

A Topic is a cache entry that can be refreshed individually. Refreshing cache instances happens automatically as new data propagates through the network of buses

uTwin instances act as a distributed networks of caches that can communicate to retrieve values without requesting a new publication, in case a uTwin instance is lacking a Topic entry in its own cache, by retrieving the last event from the cache (uTwin instance) running on the same device as the publisher of the topic). Using the analogy of a cache, it may also be useful to implement, later, a flush() command, that would remove the last known state for specific Topics, or all Topics of a given uDevice, etc.

3. Interface

The proposal defines a new Digital Twin service, named uTwin, exposing the following API:

3.1. Access to last known state

API: rpc GetLastEvent(Topic) returns (GetLastEventResponse)

GetLastEvent() sends back a CE that was stored in the uTwin instance. uTwin’s behavior is similar to a cache, it therefore has no "obligation" to retain the data and in worst case it will simply not provide the last published event. Applications that make use of uTwin MUST therefore account for the possibility that the uTwin cannot deliver the event they are requesting. This may happen in the following cases:

  • uTwin is out of memory and cannot store new incoming events (the policy that defines what events are prioritized to be stored is implementation-dependent)

  • uTwin has restarted and its internal cache that stores the last events is not persistent

The implementation of GetLastEvent() MUST enforce permissions associated with the Topic being requested

3.2. Set last known state

API: rpc SetLastEvent(SetLastEventRequest) return (Google.rpc.Status)

This function enables an "external" component to set the last event of a given Topic.

Warning
Usage of this function MUST be restricted to uPlatform components, specifically the uBus

The implementation of SetLastEvent MUST enforce permissions associated with the Topic being requested. Either checking permission for each request, or if calling this API is structurally embedded inside uBus

3.3. Remote last known state

A uTwin instance MUST run on each uDevice. Each uTwin instance MUST store the last published event on each Topic it 'manages', including event received by Streamers (therefore remotely published) and published to 'local' subscribers.

With this mechanism, all devices with at least 1 subscriber of a given Topic will receive, and keep the last event on the Topic.

While uTwin is a standalone functional entity, for implementation purposes it MAY be bundled with other uPlatform components for optimization purposes. Whatever the implementation choice, the uTwin service MUST be exposed as a core service available on each uDevice

4. Implementation Principle

The basic idea of uTwin is to store pairs of (Topic, CE), Topic (i.e. in the format of an uri, therefore including the device name, publishing uE and resource) being used as a key for queries.

One uTwin instance per device is created. The uBus of each device is responsible to feed the uTwin database by calling SetLastEvent() for each incoming CE with type=pub that it routes, therefore achieving the desired behavior of a creating a cache of all received events on the device.

Note
MUST store ingress (to the uBus) published events; egress are merge copies of ingress, therefore mere copies

4.1. Unitary Access

Access to a Topic is done with subscriptions. The intrinsic property of a subscription is that all events published, to said topic, will be received by the subscriber.

In some cases, a uE might require one-time access to a Topic, that is, to receive only the last event published on a Topic, without receiving future events that will be published. uTwin can be used for this purpose. There are 4 possible cases in this scenario:

  • The requested Topic is already subscribed by another uE running on the same device:

    • The last published event has already been stored in the uTwin instance for the device, and as a result, can simply be returned when requested by GetLastEvent()

  • The requested Topic has never been subscribed by any uE running on the same device: No event has ever been stored for said Topic because no event has ever been received! One property of any uTwin instance is that it automatically stores the last event of all active Topics of the device it runs on, as long as there is at least one subscriber of this Topic. To retrieve the last published event, the remote uTwin sends a rpc request to the uTwin instance running on the device where the service publishing the data runs. Otherwise, the uTwin could return an error, indicating that no such event is stored in the uTwin instance

  • The request Topic had a subscriber in the past but the subscriber has unsubscribed. The last event received on the device (and therefore stored in the uTwin instance) is now outdated:

    • The only way that uTwin can get a hint of this scenario is by looking at the published date of the stored CE. If the CE is considered "too old", uTwin retrieves the latest value using the same mechanism as described in the previous case.

  • The requested Topic never had a subscriber:

    • In this scenario, with current uProtocol specification, the uTwin will return an error UNAVAILABLE