This post is older than 2 years and might not be relevant anymore
More Info: Consider searching for newer posts

What is the difference between a BLE central reading from a peripheral versus a peripheral notifying the central in term of resources drained?

Suppose a BLE central needs to get sensor data from 10 peripheral sensors. Given that there is a limit to the number of connections a BLE central can have, is it better for the central to read from peripheral because it uses lesser resources compared to notify?

Parents
  • @helpme: Could you give me more information on why you think read command would use less resource compare to notify ?

    As far as I know, sending notify is more efficient than read command when thinking of the number of packet needed to send data (1 packets vs 2 packet).

    The only advantage of read command I can think of is that the client (central) doesn't have to wait for notification but has control of when to get it.

    [EDITED] Another advantage of using notify is to avoid the delay by slave latency. The peripheral can wake up in the middle of the latency sleeping period to send notification, when with read, the central have to wait until the next wake up of the latency sleeping period to get the data which only comes on next connection event after the read command.

  • To be available the peripheral will need to be advertising, so there will still be periodic radio traffic.

    My guess is that it really depends on the particular parameters of Advertising Interval vs. connection timing (Connection Interval, Slave Latency, and Connection Supervision Timeout). When notifying the peripheral can skip several connection events (slave latency) if there isn't an update. If this total skip time is long enough it may consume less power than advertising would.

Reply
  • To be available the peripheral will need to be advertising, so there will still be periodic radio traffic.

    My guess is that it really depends on the particular parameters of Advertising Interval vs. connection timing (Connection Interval, Slave Latency, and Connection Supervision Timeout). When notifying the peripheral can skip several connection events (slave latency) if there isn't an update. If this total skip time is long enough it may consume less power than advertising would.

Children
No Data
Related