Bird
Raised Fist0
IOT Protocolsdevops~5 mins

Device shadow (digital twin) in IOT Protocols - Time & Space Complexity

Choose your learning style10 modes available

Start learning this pattern below

Jump into concepts and practice - no test required

or
Recommended
Test this pattern10 questions across easy, medium, and hard to know if this pattern is strong
Time Complexity: Device shadow (digital twin)
O(n)
Understanding Time Complexity

When working with device shadows, we want to know how the time to update or retrieve the shadow changes as the number of devices grows.

We ask: How does the work grow when more devices or updates happen?

Scenario Under Consideration

Analyze the time complexity of the following code snippet.


// Pseudocode for updating device shadows
for each device in deviceList:
  fetch current shadow state
  apply updates
  save updated shadow

This code updates the shadow state for each device one by one.

Identify Repeating Operations

Identify the loops, recursion, array traversals that repeat.

  • Primary operation: Looping through each device in the list.
  • How many times: Once for every device, so as many times as there are devices.
How Execution Grows With Input

As the number of devices increases, the total work grows directly with it.

Input Size (n)Approx. Operations
1010 updates
100100 updates
10001000 updates

Pattern observation: Doubling the devices doubles the work needed.

Final Time Complexity

Time Complexity: O(n)

This means the time to update all device shadows grows in a straight line with the number of devices.

Common Mistake

[X] Wrong: "Updating multiple device shadows happens instantly regardless of device count."

[OK] Correct: Each device shadow update takes time, so more devices mean more total time.

Interview Connect

Understanding how device shadow updates scale helps you explain system behavior clearly and shows you grasp real-world IoT challenges.

Self-Check

"What if we batch update device shadows instead of one by one? How would the time complexity change?"

Practice

(1/5)
1. What is the main purpose of a device shadow in IoT?
easy
A. To keep a virtual copy of a device's state for synchronization
B. To physically store device hardware components
C. To replace the device's firmware remotely
D. To encrypt device communication data

Solution

  1. Step 1: Understand device shadow concept

    A device shadow is a virtual representation of a device's state, not a physical component or firmware.
  2. Step 2: Identify its main use

    It stores desired and reported states to keep device and cloud synchronized, especially when devices are offline.
  3. Final Answer:

    To keep a virtual copy of a device's state for synchronization -> Option A
  4. Quick Check:

    Device shadow = virtual state copy [OK]
Hint: Device shadow = virtual device state copy [OK]
Common Mistakes:
  • Confusing device shadow with physical device hardware
  • Thinking device shadow replaces device firmware
  • Assuming device shadow encrypts data
2. Which JSON field in a device shadow document holds the desired state of the device?
easy
A. "reported"
B. "desired"
C. "metadata"
D. "version"

Solution

  1. Step 1: Recall device shadow JSON structure

    The device shadow JSON has fields like "desired" and "reported" to represent states.
  2. Step 2: Identify desired state field

    The "desired" field contains the state the cloud wants the device to have.
  3. Final Answer:

    "desired" -> Option B
  4. Quick Check:

    Desired state = "desired" field [OK]
Hint: "desired" field stores target device state [OK]
Common Mistakes:
  • Mixing up "reported" and "desired" fields
  • Confusing "metadata" with state data
  • Thinking "version" holds state info
3. Given this device shadow snippet:
{"state": {"desired": {"power": "on"}, "reported": {"power": "off"}}}

What will the device shadow report after the device updates its state to match the desired power?
medium
A. {"state": {"desired": {"power": "off"}, "reported": {"power": "off"}}}
B. {"state": {"desired": {"power": "on"}, "reported": {"power": "off"}}}
C. {"state": {"desired": {"power": "on"}, "reported": {"power": "on"}}}
D. {"state": {"desired": {}, "reported": {"power": "on"}}}

Solution

  1. Step 1: Understand initial shadow states

    The desired state requests power "on"; the reported state shows power "off" initially.
  2. Step 2: Update reported state after device changes

    When the device matches the desired state, the reported state updates to "power": "on".
  3. Final Answer:

    {"state": {"desired": {"power": "on"}, "reported": {"power": "on"}}} -> Option C
  4. Quick Check:

    Reported state matches desired after update [OK]
Hint: Reported state updates to match desired after device sync [OK]
Common Mistakes:
  • Assuming desired state changes after device update
  • Leaving reported state unchanged
  • Removing desired state incorrectly
4. You receive this device shadow update error:
{"error": "Invalid JSON format"}

Which of these shadow update requests is causing the error?
medium
A. {"state": {"desired": {"temperature": 22}}}
B. {"state": {"desired": {"temperature": 22}, "reported": {"temperature": 22}}}
C. {"version": 1, "state": {"desired": {"temperature": 22}, "reported": {"temperature": 22}}}
D. {"state": {"desired": {"temperature": 22}, "reported": {"temperature": 22}"}}

Solution

  1. Step 1: Check JSON syntax of each option

    {"state": {"desired": {"temperature": 22}, "reported": {"temperature": 22}"}} has an extra double quote after the reported object closing brace, breaking JSON format.
  2. Step 2: Identify invalid JSON causing error

    Invalid JSON causes the "Invalid JSON format" error in device shadow update.
  3. Final Answer:

    {"state": {"desired": {"temperature": 22}, "reported": {"temperature": 22}"}} -> Option D
  4. Quick Check:

    Invalid JSON syntax = error [OK]
Hint: Look for extra or missing quotes/braces in JSON [OK]
Common Mistakes:
  • Overlooking extra quotes or commas
  • Confusing valid JSON with similar invalid syntax
  • Assuming error is from device, not JSON format
5. You want to ensure a device shadow only updates the reported state if the device is online. Which approach best achieves this?
hard
A. Use a device shadow update callback to confirm device state before updating reported state
B. Delete the device shadow when device is offline
C. Update reported state immediately on cloud request without device confirmation
D. Set desired state to null when device is offline

Solution

  1. Step 1: Understand device shadow update flow

    Reported state should reflect actual device state, so cloud must confirm device is online and updated.
  2. Step 2: Choose method to confirm device state

    Using a callback or acknowledgment from the device before updating reported state ensures accuracy.
  3. Final Answer:

    Use a device shadow update callback to confirm device state before updating reported state -> Option A
  4. Quick Check:

    Confirm device state before reported update [OK]
Hint: Confirm device state via callback before updating reported [OK]
Common Mistakes:
  • Updating reported state without device confirmation
  • Deleting shadow causing loss of state info
  • Setting desired state to null instead of managing reported