Communicating arbitrary attributes using a predefined characteristic

Information

  • Patent Grant
  • 9445451
  • Patent Number
    9,445,451
  • Date Filed
    Monday, October 20, 2014
    10 years ago
  • Date Issued
    Tuesday, September 13, 2016
    8 years ago
  • Inventors
  • Original Assignees
  • Examiners
    • Kim; Wesley
    • Chakraborty; Raj
    Agents
    • Stupp; Steven
    • Aurora Consulting Group LLC
Abstract
An electronic device that communicates input messages and output messages with another electronic device using a Bluetooth Low Energy communication protocol is described. In particular, the electronic device receives input messages using a predefined characteristic to convey input information associated with a set of input attribute types. A given input message includes one or more input-command characters specifying a given input attribute type in the set of input attribute types and, optionally, an input delimiter and an input value in an input argument associated with the given input attribute type. Moreover, the electronic device provides output messages using the predefined characteristic to convey output information associated with a set of output attribute types. A given output message includes one or more output-command characters specifying a given output attribute type in the set of output attribute types. In this way, the predefined characteristic can be repurposed to convey other attribute types.
Description
BACKGROUND

1. Field


The described embodiments relate to techniques for communicating information in a wireless network. In particular, the described embodiments relate to techniques for communicating an arbitrary attribute type using a predefined characteristic having a numerical identifier.


2. Related Art


Wireless communication is an increasingly popular technology for communicating information between electronic devices. In particular, these electronic devices may include networking subsystem that implement a network interface for a wireless local area network such as: a wireless network described in the Institute of Electrical and Electronics Engineers (IEEE) 802.11 standard, Bluetooth® (from the Bluetooth Special Interest Group of Kirkland, Wash.), and/or another type of wireless network.


However, while these specifications facilitate communication between electronic devices, they are often inflexible. This can make it difficult for electronic devices to communicate with each other.


Using Bluetooth Low Energy as an illustration, characteristics (which are sometimes referred to as ‘attribute types’) can be defined to allow associated logical values to be communicated between electronic devices. Thus, a heart-rate monitor may have predefined characteristics for the heart rate of a user or the remaining battery life. When one of these predefined characteristics is invoked in message received by the heart-rate monitor, the heart-rate monitor may return a corresponding message with a current value of the heart rate or the remaining battery life. However, if the desired attributes types are not known in advance, it can be difficult to use characteristics to communicate information between electronic devices. This inflexibility may make it difficult for users to perform basic tasks, which may reduce user satisfaction.


SUMMARY

The described embodiments relate to an electronic device. This electronic device includes: an antenna; and an interface circuit, coupled to the antenna, which communicates with another electronic device using a Bluetooth Low Energy (BTLE) communication protocol. During operation the electronic device receives input messages using a predefined characteristic having a numerical identifier to convey input information associated with a set of input attribute types. A given input message includes one or more input-command characters specifying a given input attribute type in the set of input attribute types and, when the given input message includes an input value in an input argument associated with the given input attribute type, the given input message includes an input delimiter between the one or more input-command characters and the input argument. Moreover, the electronic device provides output messages using the predefined characteristic to convey output information associated with a set of output attribute types. A given output message includes one or more output-command characters specifying a given output attribute type in the set of output attribute types and, when the given output message includes an output value in an output argument associated with the given output attribute type, the given output message includes an output delimiter between the one or more output-command characters and the output argument.


Note that the input delimiter may include: a tab, and an ASCII delimiter. Moreover, the input delimiter may include an invalid character for a Service Set Identifier. Furthermore, the output delimiter may include a space or a comma.


Additionally, a maximum length of the given output message may be less than a maximum length of the given input message. For example, the maximum length of the given output message may be less than or equal to 22 characters, while the maximum length of the given input message may be much larger.


In some embodiments, when the electronic device receives an input message with an information request, the electronic device asynchronously provides one or more output messages with the requested information. In particular, the one or more output messages may be provided over time without the electronic device receiving further input messages related to the information request from the other electronic device.


Moreover, when the electronic device receives an input message with an information request and the requested information exceeds a maximum length of the given output message, the electronic device may provide the requested information in a set of output messages. A first output message in the set of output messages may specify a number of output messages in the set of output messages. Furthermore, output messages between the first output message and a final output message in the set of output messages may specify its position in the set of output messages and may include a portion of the requested information. Additionally, the final output message in the set of output messages may indicate that the set of output messages is complete.


Another embodiment provides a computer-program product for use in conjunction with the electronic device. This computer-program product may include instructions for at least some of the aforementioned operations performed by the electronic device.


Another embodiment provides a method for communicating the input messages and the output messages with the other electronic device using the BTLE communication protocol. This method may include at least some of the aforementioned operations performed by the electronic device.


The preceding summary is provided as an overview of some exemplary embodiments and to provide a basic understanding of aspects of the subject matter described herein. Accordingly, the above-described features are merely examples and should not be construed as narrowing the scope or spirit of the subject matter described herein in any way. Other features, aspects, and advantages of the subject matter described herein will become apparent from the following Detailed Description, Figures, and Claims.





BRIEF DESCRIPTION OF THE FIGURES


FIG. 1 is a block diagram illustrating electronic devices communicating in accordance with an embodiment of the present disclosure.



FIG. 2 is a flow diagram illustrating a method for communicating input messages and output messages among at least some of the electronic devices of FIG. 1 using a Bluetooth Low Energy (BTLE) communication protocol in accordance with an embodiment of the present disclosure.



FIG. 3 is a block diagram illustrating an input message associated with a predefined characteristic and an output message associated with the predefined characteristic communicated among at least some of the electronic devices of FIG. 1 in accordance with an embodiment of the present disclosure.



FIG. 4 is a drawing illustrating communication among at least some of the electronic devices of FIG. 1 in accordance with an embodiment of the present disclosure.



FIG. 5 is a block diagram illustrating one of the electronic devices in FIG. 1 in accordance with an embodiment of the present disclosure.





Table 1 provides input messages communicated among at least some of the electronic devices of FIG. 1 in accordance with an embodiment of the present disclosure.


Table 2 provides output messages communicated among at least some of the electronic devices of FIG. 1 in accordance with an embodiment of the present disclosure.


Note that like reference numerals refer to corresponding parts throughout the drawings. Moreover, multiple instances of the same part are designated by a common prefix separated from an instance number by a dash.


DETAILED DESCRIPTION

An electronic device that communicates input messages and output messages with another electronic device using a Bluetooth Low Energy (BTLE) communication protocol is described. In particular, the electronic device receives input messages using a predefined characteristic having a numerical identifier to convey input information associated with a set of input attribute types. A given input message includes one or more input-command characters specifying a given input attribute type in the set of input attribute types and, optionally, an input delimiter and an input value in an input argument associated with the given input attribute type. Moreover, the electronic device provides output messages using the predefined characteristic to convey output information associated with a set of output attribute types. A given output message includes one or more output-command characters specifying a given output attribute type in the set of output attribute types and, optionally, an output delimiter and an output value in an output argument associated with the given output attribute type.


In this way, the electronic device may repurpose the predefined characteristic to allow information associated with an arbitrary attribute type (or command) to be communicated between the electronic device and the other electronic device. This flexibility may allow the BTLE communication protocol to be used even when the desired attributes types are not known in advance. Consequently, this communication protocol may allow users of the electronic device to perform basic tasks and a wide range of applications, which may increase user satisfaction with the electronic device.


In the discussion that follows the input packets and the output packets may be transmitted and received by electronic devices using radios that communicate packets in accordance with a wireless-local-area-network (WLAN) communication protocol, such as: an Institute of Electrical and Electronics Engineers (IEEE) 802.11 standard (which is sometimes referred to as ‘Wi-Fi®,’ from the Wi-Fi® Alliance of Austin, Tex.), Bluetooth® (from the Bluetooth Special Interest Group of Kirkland, Wash.), and/or another type of wireless interface. In the discussion that follows, BTLE is used as an illustrative example. However, a wide variety of communication protocols may be used.


Communication among electronic devices is shown in FIG. 1, which presents a block diagram illustrating, which presents a block diagram illustrating communication among electronic device 110, electronic device 112 and electronic device 114 (either of which may be another instance of electronic device 110, a legacy electronic device that does not communicate wirelessly or electrically with electronic device 110, an access point, or a portable electronic device, e.g., a cellular telephone), and with optional computer 122 via optional network 120 (such as the Internet, a wireless local area network, an Ethernet network, an intra-net, an optical network, etc.). In particular, electronic devices 110, 112 and/or 114 may wirelessly communicate while: transmitting advertising frames on wireless channels, detecting one another by scanning wireless channels, establishing connections (for example, by transmitting association requests), and/or transmitting and receiving packets (which may include the association requests and/or additional information as payloads).


As described further below with reference to FIG. 5, electronic devices 110, 112 and/or 114 may include subsystems, such as: a networking subsystem, a memory subsystem and a processor subsystem. In addition, electronic devices 110, 112 and/or 114 may include radios 116 in the networking subsystems. More generally, electronic devices 110, 112 and/or 114 can include (or can be included within) any electronic devices with the networking subsystems that enable these electronic devices to wirelessly communicate with each other. This wireless communication can comprise transmitting advertisements on wireless channels to enable electronic devices to make initial contact or detect each other, followed by exchanging subsequent data/management frames (such as association requests and responses) to establish a connection, configure security options (e.g., Internet Protocol Security), transmit and receive packets or frames via the connection, etc.


As can be seen in FIG. 1, wireless signals 118 (represented by a jagged line) are transmitted from a radio 114-1 in electronic device 110. These wireless signals are received by at least one of electronic devices 112 and/or 114 (such as electronic device 112). In particular, electronic device 110 may transmit messages or packets. In turn, these packets may be received by radio 116-2 in electronic device 112. This may allow electronic device 110 to communicate information to electronic device 112. While FIG. 1 illustrates electronic device 110 transmitting packets, note that electronic device 110 may also receive packets from electronic devices 112 and/or 114.


In the described embodiments, processing of a packet or frame in electronic devices 110, 112 and/or 114 includes: receiving wireless signals 118 with the packet or frame; decoding/extracting the packet or frame from received wireless signals 118 to acquire the packet or frame; and processing the packet or frame to determine information contained in the packet or frame (such as the information included in the payload). For example, the information may include an output message from electronic device 112. Note that the communication between electronic device 110 and a given one of electronic devices 112 and 114 (such as electronic device 112) may be characterized by a variety of performance metrics, such as: a data rate, a data rate for successful communication (which is sometimes referred to as a ‘throughput’), an error rate (such as a retry or resend rate), a mean-square error of equalized signals relative to an equalization target, intersymbol interference, multipath interference, a signal-to-noise ratio, a width of an eye pattern, a ratio of number of bytes successfully communicated during a time interval (such as 1-10 s) to an estimated maximum number of bytes that can be communicated in the time interval (the latter of which is sometimes referred to as the ‘capacity’ of a channel or link), and/or a ratio of an actual data rate to an estimated data rate (which is sometimes referred to as ‘utilization’).


Electronic device 110 may use predefined characteristics (or attributes types) having associated numerical identifiers to communicate information, such as commands and/or associated values of arguments with electronic devices 112 and/or 114. However, when the desired characteristics are not known in advance or need to be modified, the communication technique may be used to dynamically repurpose a predefined characteristic. As described further below with reference to FIGS. 2-4, in order to address this challenge electronic device 110 (as well as electronic devices 112 and/or 114) may receive input messages using a predefined characteristic having a numerical identifier (such as a universally unique identifier) to convey input information associated with a set of input attribute types. A given input message may include one or more input-command characters specifying a given input attribute type in the set of input attribute types and, when the given input message includes an input value in an input argument associated with the given input attribute type, the given input message may include an input delimiter between the one or more input-command characters and the input argument. Note that the input delimiter may include: a tab, and an ASCII delimiter (such as: ASCII number 28, 29, 30 or 31). Moreover, the input delimiter may include an invalid character for a Wi-Fi Service Set Identifier. Thus, by using key-value pairs (i.e., the command characters and the optional arguments) electronic device 110 may communicate an arbitrary attribute type using the predefined characteristic.


Moreover, electronic device 110 may provide output messages using the predefined characteristic to convey output information associated with a set of output attribute types. A given output message may include one or more output-command characters specifying a given output attribute type in the set of output attribute types and, when the given output message includes an output value in an output argument associated with the given output attribute type, the given output message may include an output delimiter (such as a space or a comma) between the one or more output-command characters and the output argument.


In general, there may be constraints on the length of the output messages. Consequently, a maximum length of the given output message may be less than a maximum length of the given input message. For example, the maximum length of the given output message may be less than or equal to 22 characters, while the maximum length of the given input message may be much larger.


In some embodiments, when electronic device 110 receives an input message with an information request, electronic device 110 asynchronously provides one or more output messages with the requested information. In particular, the one or more output messages may be provided over time without electronic device 110 receiving further input messages related to the information request from electronic device 112. Thus, electronic device 112 may subscribe to a channel associated with electronic device 110. Then, after providing the information request, electronic device 112 may receive the one or more output messages from electronic device 110 as the requested information becomes available and/or when values in the attributes change. Consequently, the communication technique may allow electronic device 110 to implement a wireless serial port to electronic device 112.


Furthermore, with certain operating systems (such as Android from Google, Inc. of Mountain View, Calif.) the maximum length of the output messages may be addressed by transmitting multiple output messages to communicate the requested information while still being compliant with a BTLE specification or standard. For example, when electronic device 110 receives an input message with an information request and the requested information exceeds a maximum length of the given output message, electronic device 110 may provide the requested information in a set of output messages. A first output message in the set of output messages may specify a number of output messages in the set of output messages. Furthermore, output messages between the first output message and a final output message in the set of output messages may specify its position in the set of output messages and may include a portion of the requested information. Additionally, the final output message in the set of output messages may indicate that the set of output messages is complete. This information may allow electronic device 112 to process the set of output messages to extract the requested information.


Although we describe the network environment shown in FIG. 1 as an example, in alternative embodiments, different numbers or types of electronic devices may be present. For example, some embodiments comprise more or fewer electronic devices. As another example, in another embodiment different electronic devices are transmitting and/or receiving packets or frames.


We now further describe the communication technique. FIG. 2 presents embodiments of a flow diagram illustrating method 200 for communicating input messages and output messages with another electronic device using a BTLE communication protocol, which may be performed by an electronic device, such as one of electronic devices 110, 112 and 114 (FIG. 1). During operation, the electronic device receives the input messages using a predefined characteristic (operation 210) having a numerical identifier to convey input information associated with a set of input attribute types. A given input message includes one or more input-command characters specifying a given input attribute type in the set of input attribute types and, when the given input message includes an input value in an input argument associated with the given input attribute type, the given input message includes an input delimiter between the one or more input-command characters and the input argument.


Moreover, the electronic device provides the output messages using the predefined characteristic (operation 212) to convey output information associated with a set of output attribute types. A given output message includes one or more output-command characters specifying a given output attribute type in the set of output attribute types and, when the given output message includes an output value in an output argument associated with the given output attribute type, the given output message includes an output delimiter between the one or more output-command characters and the output argument.


Note that the electronic device may asynchronously provide (operation 212), in response to receiving an input message with an information request, one or more output messages with the requested information. These one or more output messages may be provided over time without the electronic device receiving further input messages related to the information request from the other electronic device.


Furthermore, when the electronic device receives an input message with an information request and the requested information exceeds a maximum length of the given output message, the electronic device may provide the requested information in a set of output messages. A first output message in the set of output messages may specify a number of output messages in the set of output messages. Output messages between the first output message and a final output message in the set of output messages may specify its position in the set of output messages and may include a portion of the requested information. Additionally, the final output message in the set of output messages may indicate that the set of output messages is complete.


In these ways, the electronic device (for example, an interface circuit, a driver and/or software executed in an environment of the transmitting electronic device) may facilitate communication with the other electronic device. In particular, the electronic device may dynamically repurpose a predefined BTLE characteristic so an arbitrary attribute type (and, optionally, a value of an argument associated with the arbitrary attribute type) can be received or transmitted to one of electronic devices 12 and/or 114 using the predefined BTLE characteristic. This capability may allow additional tasks, services and applications to be flexibly implemented using electronic device 110. For example, services may be offered to: users associated with electronic devices 110, 112 and/or 114 (such as owners or renters of these electronic devices), suppliers of components or spare parts, maintenance personnel, security personnel, emergency service personnel, insurance companies, insurance brokers, realtors, leasing agents, apartment renters, hotel guests, hotels, restaurants, businesses, organizations, governments, potential buyers of physical objects, a shipping or transportation company, etc. In particular, the input messages and the output messages may allow electronic device 110 to monitor an environmental condition in an environment that includes electronic device 110. This monitoring may allow electronic device 110 to adapt or change the function or operation of one or more electronic devices in FIG. 1 (such as a legacy electronic device and/or a regulator device, which may not directly communicate information with electronic device 110) based on the needs or preferences of a user associated with electronic device 110, who is, therefore, in proximity. In this way, an environmental condition (such as the temperature, humidity, an illumination pattern, etc.) in the environment may be dynamically modified. In addition, once the information associated with electronic device 110 is known, the service(s) may include maintenance notifications about electronic devices 110, 112 and/or 114. For example, electronic device 110 may include one or more sensors that monitor the environmental condition in the environment (such as an acoustic signal from a fire or carbon-monoxide detector that indicates a failing battery). Based on the environmental condition, electronic device 110 may provide a maintenance notification to a user's cellular telephone to replace the battery or to perform another remedial action (such as a repair or service to be performed on electronic device 112). Consequently, the improved functionality and services facilitated by the communication technique may promote sales of electronic device 110 (and, more generally, commercial activity) and may enhance customer satisfaction with electronic device 110.


In some embodiments of method 200 (FIG. 2), there may be additional or fewer operations. Moreover, the order of the operations may be changed, and/or two or more operations may be combined into a single operation.


In an exemplary embodiment, as shown in FIG. 3, which presents a drawing illustrating an input message 310 using a predefined characteristic having a numerical identifier and an output message 318 using the predefined characteristic communicated among electronic devices 110, 112 and/or 114 (FIG. 1). In particular, input message 310 may include one or more input-command characters 312 specifying a given input attribute type in a set of input attribute types (which are sometimes referred to as ‘commands’ or ‘input commands’). Moreover, when input message 310 includes an input value in an optional input argument 316 associated with the given input attribute type, input message 310 includes an optional input delimiter 314 between the one or more input-command characters 312 and the optional input argument 316 (such as a tab or an ASCII delimiter). This information allows the predefined characteristic to be repurposed to convey any of the set of input attribute types. Table 1 presents examples of input messages communicated among at least some of electronic devices 110, 112 and/or 114 of FIG. 1. Note that the quotation marks are included for clarity. They are not included in the input messages.












TABLE 1





Input Command
Command
Argument
Example







Set the Service Set
S
SSID
“S family_wireless_net”


Identifier (SSID)





Set the password
P
Password
“P johnsons”


Set Wi-Fi secure
X
Yes or No
“X Yes”


Tell the electronic
NetworkConfigCompleted
None
“NetworkConfigCompleted”


device that the





network configuration





is complete. This also





causes network





services to be restarted





Tells the electronic
ConfigCompleted
None
“ConfigCompleted”


device that everything





is done





Request serial number
ReqSerialNumber
None
“ReqSerial Number”


Request Wi-Fi
ReqWifiStatus
None
“ReqWifiStatus”


connection status





Request version
ReqBLEAPIVersion
None
“ReqBLEAPIVersion”


number





Request a scan of
ReqWiFiScan
None
“ReqWiFiScan”


Wi-Fi electronic





devices





Set PubNub channel
B
Pubnub
“B <pubnub channel>”




channel



Set the electronic
T
Device
“T <device token>”


device token

token



Request the electronic
ReqDeviceType
None
“ReqDevType”


device type





Send pubnub channel
PK
Pubnub
“PK <pubnub publish key>”


key

publish key



Send pubnub
SK
Pubnub
“SK <pubnub subscriber


subscriber key

subscriber
key>”




key



Tell the electronic
ConfigCompleted
None
“ConfigCompleted”


device the





configuration is





completed





Set timezone
TZ
Hours
“TZ-6”




offset from





Coordinated





Universal





time



Set the electronic
DN
Electronic
“TZ 3”


device number

device





number









Furthermore, output message 318 may include one or more output-command characters 320 specifying a given output attribute type in a set of output attribute types (which are sometimes referred to as ‘commands’ or ‘output commands’). Additionally, when output message 318 includes an output value in an optional output argument 324 associated with the given output attribute type, output message 318 includes an optional output delimiter 322 between the one or more output-command characters 320 and the optional output argument 324 (such as a space or a comma). This information allows the predefined characteristic to be repurposed to convey any of the set of output attribute types. Table 2 presents examples of output messages communicated among at least some of electronic devices 110, 112 and/or 114 of FIG. 1. Note that the quotation marks are included for clarity. They are not included in the output messages. Because of constraints of the maximum length of the output message, requested information may be split into multiple messages. For example, in response to a request for a scan of Wi-Fi devices, the electronic device may respond with “AP 165,11,” i.e., the first detected Wi-Fi electronic device is 165 and 11 more output messages will follow. Subsequent output messages may indicate the message number and another detected Wi-Fi electronic device, such as “L02 ATT808.” Finally, the last output message in this set of output messages may indicate that the set is complete, such as “EAP.”












TABLE 2





Output Command
Command
Argument
Example







Serial number
N
Serial
“N <serial number>”




number



Wi-Fi Connection
WS
Connected
“WS connected”


Status

or Not





connected



BTLE Application
BLEAPIER
1
“BLEAPIVER 1”


Programming





Interface Version





Begin sending APs
AP
AP value,
“AP 165, 11”




number of





messages



AP message
L<message number>
AP value
“L02 ATT808”




or





identifier



End sending AP
EAP
None
“EAP”


Electronic device type
DT
Electronic
“DT <device type>”




device





type









In an exemplary embodiment, a service associated with the electronic device (to which the other electronic device can subscribe) has a universally unique identifier such as 0000000000001000800000805F9B0000, and includes or is associated with the predefined characteristic that has a numerical identifier such as a universally unique identifier of 0000000000001000800000805F9B0001. This service allows this predefined characteristic to emulate a serial port between the electronic device and the other electronic device, such as a user's cellular telephone. In order to receive output messages from the electronic device, the other electronic device may subscribe to be notified when a value of one of the output attribute types changes. This allows the other electronic device to request information from the electronic device and to have the requested information sent back asynchronously by the electronic device without the other electronic device having to poll the electronic device. Note that, by default, when the predefined characteristic is read, the value return in the output argument may be the serial number of the electronic device.


As shown in FIG. 3, the general format of an input message to the electronic device may be:

    • <Command><Tab><Argument>.


      A tab may be used as optional input delimiter 314 because it is not a valid character for a Service Set Identifier. Note that all the data sent to the electronic devices in input messages and received from the electronic device in output messages may be ASCII encoded. Moreover, while the number of characters that may be allowed to be sent to the electronic device from the other electronic device may be relatively large, the maximum size or length of an output message sent from the electronic device to the other electronic device may be 22 characters.


Embodiments of the communication technique are further illustrated in FIG. 4, which presents a drawing illustrating communication between electronic device 110 and electronic device 112 (FIG. 1). In particular, interface circuit 410 receives an input message 412 using a predefined characteristic having a numerical identifier from electronic device 112. This input message may include one or more input-command characters specifying a given input attribute type in a set of input attribute types. Moreover, when electronic device 112 writes information to electronic device 110 (i.e., when the given input message includes an input value in an input argument associated with the given input attribute type), the given input message includes an input delimiter (such as a tab) between the one or more input-command characters and the input argument. For example, the one or more input-command characters may request that electronic device 110 characterize a wireless-network environment, such as information about other electronic devices in a wireless network that includes electronic device 110.


In response, interface circuit 410 may characterize the other electronic devices in a wireless network by scanning 414 for advertisements (such as advertisement 416) from the other electronic devices in a wireless network. As other electronic devices (such as electronic device 114) are detected, interface circuit 410 may asynchronously provide an output message 418 using the predefined characteristic to electronic device 112. This output message may include one or more output-command characters specifying a given output attribute type in a set of output attribute types. Furthermore, when the given output message includes an output value in an output argument associated with the given output attribute type, the given output message may include an output delimiter (such as a comma) between the one or more output-command characters and the output argument.


For example, if the requested information associated with the one or more input-command characters in input message 420 exceeds a maximum length of the given output message, interface circuit 410 may provide the requested information in a set of output messages 422. As noted previously, the output messages in the set of output messages 422 may specify: a start of the set of output messages 422, a relative or absolute position of a given output message in the set of output messages 422, and the end of the set of output messages 422.


We now describe embodiments of the electronic device. FIG. 5 presents a block diagram illustrating an electronic device 500, such as one of electronic devices 110, 112 and/or 114. This electronic device includes processing subsystem 510 (and, more generally, an integrated circuit or a control mechanism), memory subsystem 512, networking subsystem 514, power subsystem 516, switching subsystem 520 and optional sensor subsystem 524 (i.e., a data-collection subsystem and, more generally, a sensor mechanism). Processing subsystem 510 includes one or more devices configured to perform computational operations and to execute techniques to process sensor data. For example, processing subsystem 510 can include one or more microprocessors, application-specific integrated circuits (ASICs), microcontrollers, programmable-logic devices, and/or one or more digital signal processors (DSPs).


Memory subsystem 512 includes one or more devices for storing data and/or instructions for processing subsystem 510, networking subsystem 514 and/or optional sensor subsystem 524. For example, memory subsystem 512 can include dynamic random access memory (DRAM), static random access memory (SRAM), and/or other types of memory. In some embodiments, instructions for processing subsystem 510 in memory subsystem 512 include: one or more program modules or sets of instructions (such as one or more program modules 532), which may be executed in an operating environment (such as operating system 534) by processing subsystem 510. Note that the one or more computer programs may constitute a computer-program mechanism. Moreover, instructions in the various modules in memory subsystem 512 may be implemented in: a high-level procedural language, an object-oriented programming language, and/or in an assembly or machine language. Furthermore, the programming language may be compiled or interpreted, e.g., configurable or configured (which may be used interchangeably in this discussion), to be executed by processing subsystem 510.


In addition, memory subsystem 512 can include mechanisms for controlling access to the memory. In some embodiments, memory subsystem 512 includes a memory hierarchy that comprises one or more caches coupled to a memory in electronic device 500. In some of these embodiments, one or more of the caches is located in processing subsystem 510.


In some embodiments, memory subsystem 512 is coupled to one or more high-capacity mass-storage devices (not shown). For example, memory subsystem 512 can be coupled to a magnetic or optical drive, a solid-state drive, or another type of mass-storage device. In these embodiments, memory subsystem 512 can be used by electronic device 500 as fast-access storage for often-used data, while the mass-storage device is used to store less frequently used data.


Networking subsystem 514 includes one or more devices configured to couple to and communicate on a wired and/or wireless network (i.e., to perform network operations and, more generally, communication), including: interface circuit 528 (such as a BTLE communication circuit) and one or more associated antennas 530. (While FIG. 5 includes one or more antennas 530, in some embodiments electronic device 500 includes one or more nodes on interface circuit 528, e.g., pads, which can be coupled to one or more antennas 530. Thus, electronic device 500 may or may not include one or more antennas 530.) For example, networking subsystem 514 can include: a ZigBee® networking subsystem, a Bluetooth networking system (such as BTLE), a cellular networking system (e.g., a 3G/4G network such as UMTS, LTE, etc.), a universal serial bus (USB) networking system, a networking system based on the standards described in IEEE 802.11 (e.g., a Wi-Fi networking system), an Ethernet networking system, an infra-red communication system, a power-line communication system and/or another communication system (such as a near-field-communication system or an ad-hoc-network networking system). Note that the combination of interface circuit 528 and at least one of one or more antennas 530 may constitute a radio.


Moreover, networking subsystem 514 includes processors, controllers, radios/antennas, sockets/plugs, and/or other devices used for coupling to, communicating on, and handling data and events for each supported networking system. Note that mechanisms used for coupling to, communicating on, and handling data and events on the network for each network system are sometimes collectively referred to as a ‘network interface’ for the network system. In some embodiments, a ‘network’ between the electronic devices does not yet exist. Therefore, electronic device 500 may use the mechanisms in networking subsystem 514 for performing simple wireless communication between the electronic devices, e.g., transmitting advertising or beacon frames and/or scanning for advertising frames transmitted by other electronic devices.


Furthermore, electronic device 500 may include power subsystem 516 with one or more power sources 518. Each of these power sources may include: a battery (such as a rechargeable or a non-rechargeable battery), a DC: power supply, a transformer, and/or a switched-mode power supply. Moreover, the one or more power sources 518 may operate in a voltage-limited mode or a current-limited mode. Furthermore, these power sources may be mechanically and electrically coupled by a male or female adaptor to: a wall or electrical-outlet socket or plug (such as a two or three-pronged electrical-outlet plug, which may be collapsible or retractable), a light socket (or light-bulb socket), electrical wiring (such as a multi-wire electrical terminal), a generator, a USB port or connector, a DC-power plug or socket, a cellular-telephone charger cable, a photodiode, a photovoltaic cell, etc. This mechanical and electrical coupling may be rigid or may be remateable. Note that the one or more power sources 518 may be mechanically and electrically coupled to an external power source or another electronic device by one of the electrical-connection nodes in switch 522 in switching subsystem 520.


In some embodiments, power subsystem 516 includes or functions as a pass-through power supply for one or more electrical connectors to an external electronic device (such as an appliance or a regulator device) that can be plugged into the one or more electrical connectors. Power to the one or more electrical connectors (and, thus, the external electronic device) may be controlled locally by processing subsystem 510, switching subsystem 520 (such as by switch 522), and/or remotely via networking subsystem 514.


Furthermore, optional sensor subsystem 524 may include one or more sensor devices 526 (or a sensor array), which may include one or more processors and memory. For example, the one or more sensor devices 526 may include: a thermal sensor (such as a thermometer), a humidity sensor, a barometer, a camera or video recorder (such as a CCD or CMOS imaging sensor), one or more microphones (which may be able to record acoustic information, including acoustic information in an audio band of frequencies, in mono or stereo), a load-monitoring sensor or an electrical-characteristic detector (and, more generally, a sensor that monitors one or more electrical characteristics), an infrared sensor (which may be active or passive), a microscope, a particle detector (such as a detector of dander, pollen, dust, exhaust, etc.), an air-quality sensor, a particle sensor, an optical particle sensor, an ionization particle sensor, a smoke detector (such as an optical smoke detector or an ionizing smoke detector), a fire-detection sensor, a radon detector, a carbon-monoxide detector, a chemical sensor or detector, a volatile-organic-compound sensor, a combustible gas sensor, a chemical-analysis device, a mass spectrometer, a microanalysis device, a nano-plasmonic sensor, a genetic sensor (such as a micro-array), an accelerometer, a position or a location sensor (such as a location sensor based on the Global Positioning System or GPS), a gyroscope, a motion sensor (such as a light-beam sensor), a contact sensor, a strain sensor (such as a strain gauge), a proximity sensor, a microwave/radar sensor (which may be active or passive), an ultrasound sensor, a vibration sensor, a fluid flow sensor, a photo-detector, a Geiger counter, a radio-frequency radiation detector, and/or another device that measures a physical effect or that characterizes an environmental factor or physical phenomenon (either directly or indirectly). Note that the one or more sensor devices 526 may include redundancy (such as multiple instances of a type of sensor device) to address sensor failure or erroneous readings, to provide improved accuracy and/or to provide improved precision.


During operation of electronic device 500, processing subsystem 510 may execute one or more program modules 532, such as an environmental-monitoring application that uses one or more sensor devices 526 to monitor one or more environmental conditions in an environment that includes electronic device 500. The resulting sensor data may be used by the environmental-monitoring application to modify operation of electronic device 500 and/or the external electronic device, and/or to provide information about the environment to another (separate) electronic device (e.g., via networking subsystem 514) using the communication technique.


Within electronic device 500, processing subsystem 510, memory subsystem 512, and networking subsystem 514, power subsystem 516, switching subsystem 520 and/or optional sensor subsystem 524 may be coupled using one or more interconnects, such as bus 536. These interconnects may include an electrical, optical, and/or electro-optical connection that the subsystems can use to communicate commands and data among one another. Although only one bus 536 is shown for clarity, different embodiments can include a different number or configuration of electrical, optical, and/or electro-optical connections among the subsystems.


Electronic device 500 can be (or can be included in) a wide variety of electronic devices, such as an electronic device with at least one network interface. For example, electronic device 500 can be (or can be included in): a sensor (such as a smart sensor), a tablet computer, a smartphone, a cellular telephone, an appliance, a regulator device, a consumer-electronic device (such as a baby monitor), a portable computing device, an access point, a router, a switch, communication equipment, test equipment, a digital signal processor, a controller, a personal digital assistant, a laser printer (or other office equipment such as a photocopier), a personal organizer, a toy, a set-top box, a computing device (such as a laptop computer, a desktop computer, a server, and/or a subnotebook/netbook), a light (such as a nightlight), a space heater, an alarm, a smoke detector, a carbon-monoxide detector, an environmental monitoring device (which monitors an environmental condition in the environment that includes electronic device 500), and/or another electronic device, and/or another electronic device.


Although specific components are used to describe electronic device 500, in alternative embodiments, different components and/or subsystems may be present in electronic device 500. For example, electronic device 500 may include one or more additional processing subsystems, memory subsystems, networking subsystems, power subsystems, switching subsystems, and/or sensor subsystems. Moreover, one or more of the subsystems may not be present in electronic device 500. Furthermore, in some embodiments, electronic device 500 may include one or more additional subsystems that are not shown in FIG. 5 such as a user-interface subsystem, a display subsystem, and/or a feedback subsystem (which may include speakers and/or an optical source).


Although separate subsystems are shown in FIG. 5, in some embodiments, some or all of a given subsystem or component can be integrated into one or more of the other subsystems or component(s) in electronic device 500. For example, in some embodiments program module 522 is included in operating system 534. In some embodiments, a component in a given subsystem is included in a different subsystem.


Moreover, the circuits and components in electronic device 500 may be implemented using any combination of analog and/or digital circuitry, including: bipolar, PMOS and/or NMOS gates or transistors. Furthermore, signals in these embodiments may include digital signals that have approximately discrete values and/or analog signals that have continuous values. Additionally, components and circuits may be single-ended or differential, and power supplies may be unipolar or bipolar.


An integrated circuit may implement some or all of the functionality of networking subsystem 514, such as one or more radios. Moreover, the integrated circuit may include hardware and/or software mechanisms that are used for transmitting wireless signals from electronic device 500 and receiving signals at electronic device 500 from other electronic devices. Aside from the mechanisms herein described, radios are generally known in the art and hence are not described in detail. In general, networking subsystem 514 and/or the integrated circuit can include any number of radios. Note that the radios in multiple-radio embodiments function in a similar way to the radios described in single-radio embodiments.


In some embodiments, networking subsystem 514 and/or the integrated circuit include a configuration mechanism (such as one or more hardware and/or software mechanisms) that configures the radios to transmit and/or receive on a given channel (e.g., at a given carrier frequency). For example, in some embodiments, the configuration mechanism can be used to switch the radio from monitoring and/or transmitting on a given channel to monitoring and/or transmitting on a different channel. (Note that ‘monitoring’ as used herein comprises receiving signals from other electronic devices and possibly performing one or more processing operations on the received signals, e.g., determining if the received signal comprises an advertising frame, calculating a performance metric, etc.)


While a communication protocol compatible with BTLE was used as an illustrative example, the described embodiments of the communication technique may be used in a variety of network interfaces. Furthermore, while some of the operations in the preceding embodiments were implemented in hardware or software, in general the operations in the preceding embodiments can be implemented in a wide variety of configurations and architectures. Therefore, some or all of the operations in the preceding embodiments may be performed in hardware, in software or both. For example, at least some of the operations in the communication technique may be implemented using program module 522, operating system 534 (such as drivers for interface circuit 528) and/or in firmware in interface circuit 528. Alternatively or additionally, at least some of the operations in the communication technique may be implemented in a physical layer, such as hardware in interface circuit 528.


In the preceding description, we refer to ‘some embodiments.’ Note that ‘some embodiments’ describes a subset of all of the possible embodiments, but does not always specify the same subset of embodiments.


The foregoing description is intended to enable any person skilled in the art to make and use the disclosure, and is provided in the context of a particular application and its requirements. Moreover, the foregoing descriptions of embodiments of the present disclosure have been presented for purposes of illustration and description only. They are not intended to be exhaustive or to limit the present disclosure to the forms disclosed. Accordingly, many modifications and variations will be apparent to practitioners skilled in the art, and the general principles defined herein may be applied to other embodiments and applications without departing from the spirit and scope of the present disclosure. Additionally, the discussion of the preceding embodiments is not intended to limit the present disclosure. Thus, the present disclosure is not intended to be limited to the embodiments shown, but is to be accorded the widest scope consistent with the principles and features disclosed herein.

Claims
  • 1. An electronic device, comprising: an antenna; andan interface circuit, coupled to the antenna, configured to communicate with another electronic device using a Bluetooth Low Energy (BTLE) communication protocol, wherein the electronic device is configured to: receive input messages using a predefined characteristic having a numerical identifier to convey input information associated with a set of input attribute types including multiple input attribute types, wherein a given input message includes one or more input-command characters specifying a given input attribute type in the set of input attribute types, an input value in an input argument associated with the given input attribute type, and an input delimiter between the one or more input-command characters and the input argument, andwherein the one or more input-command characters, the input delimiter and the input value dynamically repurpose the predefined characteristic to convey any of the set of input attribute types, including an input attribute that is not known in advance; andprovide output messages using the predefined characteristic to convey output information associated with a set of output attribute types having multiple output attribute types, wherein a given output message includes one or more output-command characters specifying a given output attribute type in the set of output attribute types, an output value in an output argument associated with the given output attribute type, and an output delimiter between the one or more output-command characters and the output argument, andwherein the one or more output-command characters, the output delimiter and the output value dynamically repurpose the predefined characteristic to convey any of the set of output attribute types.
  • 2. The electronic device of claim 1, wherein the input delimiter includes one of: a tab, and an ASCII delimiter.
  • 3. The electronic device of claim 1, wherein the input delimiter includes an invalid character for a Service Set Identifier.
  • 4. The electronic device of claim 1, wherein the output delimiter includes a comma.
  • 5. The electronic device of claim 1, wherein a maximum length of the given output message is less than a maximum length of the given input message.
  • 6. The electronic device of claim 1, wherein a maximum length of the given output message is less than or equal to 22 characters.
  • 7. The electronic device of claim 1, wherein, when the electronic device receives an input message with an information request, the electronic device is configured to asynchronously provide one or more output messages with the requested information.
  • 8. The electronic device of claim 7, wherein the one or more output messages are provided over time without the electronic device receiving further input messages related to the information request from the other electronic device.
  • 9. The electronic device of claim 1, wherein, when the electronic device receives an input message with an information request and the requested information exceeds a maximum length of the given output message, the electronic device is configured to provide the requested information in a set of output messages; wherein a first output message in the set of output messages specifies a number of output messages in the set of output messages;wherein output messages between the first output message and a final output message in the set of output messages specifies its position in the set of output messages and includes a portion of the requested information; andwherein the final output message in the set of output messages indicates that the set of output messages is complete.
  • 10. A computer-program product for use in conjunction with an electronic device, the computer-program product comprising a non-transitory computer-readable storage medium and a computer-program mechanism embedded therein to communicate input messages and output messages with another electronic device using a Bluetooth Low Energy (BTLE) communication protocol, the computer-program mechanism including: instructions for receiving the input messages using a predefined characteristic having a numerical identifier to convey input information associated with a set of input attribute types including multiple input attribute types, wherein a given input message includes one or more input-command characters specifying a given input attribute type in the set of input attribute types, an input value in an input argument associated with the given input attribute type, and an input delimiter between the one or more input-command characters and the input argument, andwherein the one or more input-command characters, the input delimiter and the input value dynamically repurpose the predefined characteristic to convey any of the set of input attribute types, including an input attribute that is not known in advance; andinstructions providing the output messages using the predefined characteristic to convey output information associated with a set of output attribute types having multiple output attribute types, wherein a given output message includes one or more output-command characters specifying a given output attribute type in the set of output attribute types, an output value in an output argument associated with the given output attribute type, and an output delimiter between the one or more output-command characters and the output argument, andwherein the one or more output-command characters, the output delimiter and the output value dynamically repurpose the predefined characteristic to convey any of the set of output attribute types.
  • 11. The computer-program product of claim 10, wherein the input delimiter includes one of: a tab, and an ASCII delimiter.
  • 12. The computer-program product of claim 10, wherein the input delimiter includes an invalid character for a Service Set Identifier.
  • 13. The computer-program product of claim 10, wherein the output delimiter includes a comma.
  • 14. The computer-program product of claim 10, wherein a maximum length of the given output message is less than a maximum length of the given input message.
  • 15. The computer-program product of claim 10, wherein a maximum length of the given output message is less than or equal to 22 characters.
  • 16. The computer-program product of claim 10, wherein the computer-program mechanism includes instructions for asynchronously providing, in response to receiving an input message with an information request, one or more output messages with the requested information.
  • 17. The computer-program product of claim 16, wherein the one or more output messages are provided over time without the electronic device receiving further input messages related to the information request from the other electronic device.
  • 18. The computer-program product of claim 10, wherein the computer-program mechanism includes instructions for providing, in response to receiving an input message with an information request and when the requested information exceeds a maximum length of the given output message, the requested information in a set of output messages; wherein a first output message in the set of output messages specifies a number of output messages in the set of output messages;wherein output messages between the first output message and a final output message in the set of output messages specifies its position in the set of output messages and includes a portion of the requested information; andwherein the final output message in the set of output messages indicates that the set of output messages is complete.
  • 19. An electronic-device-implemented method for communicating input messages and output messages with another electronic device using a Bluetooth Low Energy (BTLE) communication protocol, wherein the method comprises: receiving the input messages using a predefined characteristic having a numerical identifier to convey input nformation associated with a set of input attribute types including multiple input attribute types, wherein a given input message includes one or more input-command characters specifying a given input attribute type in the set of input attribute types, an input value in an input argument associated with the given input attribute type, and an input delimiter between the one or more input-command characters and the input argument, andwherein the one or more input-command characters, the input delimiter and the input value dynamically repurpose the predefined characteristic to convey any of the set of input attribute types, including an input attribute that is not known in advance; andusing a control mechanism in the electronic device, providing the output messages using the predefined characteristic to convey output information associated with a set of output attribute types having multiple output attribute types, wherein a given output message includes one or more output-command characters specifying a given output attribute type in the set of output attribute types, an output value in an output argument associated with the given output attribute type, and an output delimiter between the one or more output-command characters and the output argument, andwherein the one or more output-command characters, the output delimiter and the output value dynamically repurpose the predefined characteristic to convey any of the set of output attribute types.
  • 20. The method of claim 19, wherein the method further comprises: asynchronously providing, in response to receiving an input message with an information request, one or more output messages with the requested information; andwherein the one or more output messages are provided over time without the electronic device receiving further input messages related to the information request from the other electronic device.
US Referenced Citations (368)
Number Name Date Kind
900595 Sanders Oct 1908 A
988665 Ripson Apr 1911 A
3030806 Merlin Apr 1962 A
3499664 Burns Mar 1970 A
3722501 Derouineau Mar 1973 A
3767933 Bogue Oct 1973 A
3895638 Ito Jul 1975 A
4093867 Shah Jun 1978 A
4286470 Lynnworth Sep 1981 A
4418333 Schwarzbach Nov 1983 A
4450436 Massa May 1984 A
4772126 Allemand Sep 1988 A
4812827 Scripps Mar 1989 A
4829283 Spang May 1989 A
4896039 Fraden Jan 1990 A
4896136 Hotovy Jan 1990 A
4984380 Anderson Jan 1991 A
5003486 Hendel Mar 1991 A
5045833 Smith Sep 1991 A
5068715 Wade Nov 1991 A
5156203 Funakoshi Oct 1992 A
5159315 Schultz Oct 1992 A
5185531 Wynn Feb 1993 A
5307051 Sedlmayr Apr 1994 A
5426501 Hokanson Jun 1995 A
5478256 Koganemaru Dec 1995 A
5492482 Lockman Feb 1996 A
5493618 Stevens Feb 1996 A
5532660 Smith Jul 1996 A
5578995 Bryant Nov 1996 A
5646591 Issa Jul 1997 A
5675070 Gelperin Oct 1997 A
5745670 Linde Apr 1998 A
5801297 Mifsud Sep 1998 A
5855494 Blaszczyk et al. Jan 1999 A
5905436 Dwight et al. May 1999 A
5936613 Jaeger Aug 1999 A
6023223 Baxter Feb 2000 A
6023233 Craven Feb 2000 A
6074089 Hollander Jun 2000 A
6077107 Hetherington Jun 2000 A
6084572 Yaniger Jul 2000 A
6158868 Chien Dec 2000 A
6216956 Ehlers Apr 2001 B1
6234642 Bokämper May 2001 B1
6257758 Culbertson Jul 2001 B1
6408704 Willeke Jun 2002 B1
6415205 Myron Jul 2002 B1
6428334 Skarie Aug 2002 B1
6442999 Baumoel Sep 2002 B1
6492907 Mccracken Dec 2002 B1
6542234 Ulrich Apr 2003 B1
6554439 Teicher Apr 2003 B1
6615147 Jonker Sep 2003 B1
6672129 Frederickson Jan 2004 B1
6677573 Nakata Jan 2004 B1
6741177 Ballantyne May 2004 B2
6753776 Drinkard Jun 2004 B2
6753786 Apperson Jun 2004 B1
6759763 Barton Jul 2004 B2
6772052 Amundsen Aug 2004 B1
6828909 Script Dec 2004 B2
6873725 Xu Mar 2005 B2
6892317 Sampath et al. May 2005 B1
6950017 Smith Sep 2005 B2
6981943 Noguchi Jan 2006 B2
6991029 Orfield Jan 2006 B2
7038398 Lys May 2006 B1
7049968 Fitzgerald May 2006 B2
7089780 Sunshine Aug 2006 B2
7098782 Peckham Aug 2006 B1
7116213 Thiesen Oct 2006 B2
7119789 Shaw Oct 2006 B1
7155317 Tran Dec 2006 B1
7166796 Nicoloau Jan 2007 B2
7166937 Wilson Jan 2007 B2
7227652 Cronch Jun 2007 B2
7257397 Shamoon Aug 2007 B2
7264377 Cooper Sep 2007 B2
7287738 Pitlor Oct 2007 B2
7304129 Saffell Dec 2007 B2
7304259 Schwarz Dec 2007 B2
7337078 Bond Feb 2008 B2
RE40437 Rosen Jul 2008 E
7400594 Pereira Jul 2008 B2
7405524 Null Jul 2008 B2
7420293 Donnelly Sep 2008 B2
7424624 Espinoza-Ibarra Sep 2008 B2
7438446 Mccann Oct 2008 B1
7492273 Sharpe Feb 2009 B2
7502199 Hori Mar 2009 B2
7515041 Eisold Apr 2009 B2
7520607 Casper Apr 2009 B2
7522036 Preuss Apr 2009 B1
7649472 Paterno Jan 2010 B1
7673525 Huang Mar 2010 B2
7685861 Lynch Mar 2010 B2
7710824 Katzer et al. May 2010 B1
7764180 Huang Jul 2010 B2
7784293 Violand Aug 2010 B2
7786879 Lax Aug 2010 B2
7818184 Penny Oct 2010 B2
7825546 Li Nov 2010 B2
7828463 Willis Nov 2010 B1
7874695 Jensen Jan 2011 B2
7905154 Jones Mar 2011 B2
7952475 Ivanov May 2011 B2
7963177 Gysling Jun 2011 B2
7992332 Lowenthal Aug 2011 B2
7994928 Richmond Aug 2011 B2
8018327 Nelson Sep 2011 B2
8051312 Foley Nov 2011 B2
8097984 Baarman Jan 2012 B2
8113069 Settles Feb 2012 B2
8125194 Nethken Feb 2012 B2
8155012 Austermann Apr 2012 B2
8170722 Elberbaum May 2012 B1
8224576 Jensen Jul 2012 B2
8242640 Lee Aug 2012 B2
8255090 Frader-Thompson Aug 2012 B2
8289135 Griffin Oct 2012 B2
8301271 Lee Oct 2012 B2
8314590 Chen Nov 2012 B2
8335936 Jonsson Dec 2012 B2
8350406 Byrne et al. Jan 2013 B2
8369135 Mani Feb 2013 B1
8451132 Van Vleet May 2013 B1
8463452 Masters Jun 2013 B2
8466626 Null Jun 2013 B2
8475367 Yuen Jul 2013 B1
8489437 Dlott Jul 2013 B1
8493618 Ishii Jul 2013 B2
8523758 Kirby Sep 2013 B1
8543247 Boss Sep 2013 B2
8564403 Landau-Holdsworth Oct 2013 B2
8583843 Rosso Nov 2013 B2
8605091 Bradbury Dec 2013 B2
8610587 Tropper Dec 2013 B2
8636271 Check Jan 2014 B2
8639391 Alberth Jan 2014 B1
8683236 Ukita Mar 2014 B2
8730004 Elfstrom et al. May 2014 B2
8823529 Reed Sep 2014 B2
8897804 Couch Nov 2014 B2
9064394 Trundle Jun 2015 B1
20010007800 Skarie Jul 2001 A1
20020011947 Stolarczyk Jan 2002 A1
20020037026 Sato Mar 2002 A1
20020050932 Rhoades May 2002 A1
20020066019 Amonou May 2002 A1
20020069076 Faris Jun 2002 A1
20020073138 Gilbert Jun 2002 A1
20020097546 Weinberger Jul 2002 A1
20020152037 Sunshine Oct 2002 A1
20020170367 Lieber Nov 2002 A1
20030028270 Peterson Feb 2003 A1
20030074092 Carrabis Apr 2003 A1
20030194904 Rupert et al. Oct 2003 A1
20030227220 Biskup Dec 2003 A1
20030227389 McGreal Dec 2003 A1
20030231495 Searfoss Dec 2003 A1
20040015572 Kang Jan 2004 A1
20040025604 Call Feb 2004 A1
20040030531 Miller Feb 2004 A1
20040069046 Sunshine Apr 2004 A1
20040075566 Stepanik Apr 2004 A1
20040147038 Lewis Jul 2004 A1
20040158193 Bui Aug 2004 A1
20040215981 Ricciardi Oct 2004 A1
20050045784 Pitlor Mar 2005 A1
20050073405 Spoltore Apr 2005 A1
20050111213 Smith May 2005 A1
20050136972 Smith Jun 2005 A1
20050148890 Hastings Jul 2005 A1
20050229452 Shimasaki Oct 2005 A1
20050276051 Caudle Dec 2005 A1
20050289378 Vorenkamp Dec 2005 A1
20060004492 Terlson Jan 2006 A1
20060119954 Casper Jun 2006 A1
20060173580 Desrochers Aug 2006 A1
20060236325 Rao Oct 2006 A1
20060238757 Silcott Oct 2006 A1
20060250236 Ackley Nov 2006 A1
20060250260 Albert Nov 2006 A1
20070038334 Chou Feb 2007 A1
20070061393 Moore Mar 2007 A1
20070109121 Cohen May 2007 A1
20070132558 Rowe Jun 2007 A1
20070138307 Khoo Jun 2007 A1
20070155349 Nelson Jul 2007 A1
20070168088 Ewing Jul 2007 A1
20070173978 Fein Jul 2007 A1
20070182963 Wright Aug 2007 A1
20070219650 Wang et al. Sep 2007 A1
20070225868 Terlson Sep 2007 A1
20070241615 Goodrich Oct 2007 A1
20070268687 Scannell Nov 2007 A1
20070276548 Uzunovic Nov 2007 A1
20070278285 Ehrensvaerd Dec 2007 A1
20080024089 Meng Jan 2008 A1
20080096620 Lee Apr 2008 A1
20080097809 Stroman Apr 2008 A1
20080106424 Bouse May 2008 A1
20080120296 Kariathungal May 2008 A1
20080123332 Searfoss May 2008 A1
20080143525 Woodbury Jun 2008 A1
20080155429 Frank et al. Jun 2008 A1
20080173817 Goldstein Jul 2008 A1
20080204258 Dayton Aug 2008 A1
20080211683 Curt Sep 2008 A1
20080221714 Schoettle Sep 2008 A1
20080279287 Asahina Nov 2008 A1
20080291036 Richmond Nov 2008 A1
20080303678 Mccredy Dec 2008 A1
20090031786 Takeuchi Feb 2009 A1
20090054799 Vrtis Feb 2009 A1
20090065596 Seem Mar 2009 A1
20090066513 Kondo Mar 2009 A1
20090073694 Scannell, Jr. Mar 2009 A1
20090096620 Kuo Apr 2009 A1
20090105558 Riley-Doucet Apr 2009 A1
20090140898 Ceballos Jun 2009 A1
20090141898 Huang Jun 2009 A1
20090154148 Meyer Jun 2009 A1
20090157839 Diederichs Jun 2009 A1
20090193578 Jang Aug 2009 A1
20090195382 Hall Aug 2009 A1
20090225480 Baxter Sep 2009 A1
20090243597 Spenik Oct 2009 A1
20090271013 Chen Oct 2009 A1
20090278868 Nakahira Nov 2009 A1
20090290156 Popescu Nov 2009 A1
20090298957 Gauthier Dec 2009 A1
20100025449 Longobardi Feb 2010 A1
20100033329 Davis Feb 2010 A1
20100070619 Chaganti Mar 2010 A1
20100071008 Hu Mar 2010 A1
20100076615 Daniel Mar 2010 A1
20100090822 Benson Apr 2010 A1
20100101264 Nishino Apr 2010 A1
20100145543 Middlemiss Jun 2010 A1
20100164742 Anderson Jul 2010 A1
20100182201 Graczyk Jul 2010 A1
20100201536 Robertson et al. Aug 2010 A1
20100228819 Wei Sep 2010 A1
20100235004 Thind Sep 2010 A1
20100249955 Sitton Sep 2010 A1
20100264871 Matouka Oct 2010 A1
20100274367 Kaufman Oct 2010 A1
20100296685 Carle Nov 2010 A1
20100298742 Perlman Nov 2010 A1
20100298957 Sanchez Rocha Nov 2010 A1
20100306033 Oved Dec 2010 A1
20100313748 Schluter Dec 2010 A1
20100318236 Kilborn Dec 2010 A1
20110007491 Robinson Jan 2011 A1
20110025499 Hoy Feb 2011 A1
20110027626 Lattin Feb 2011 A1
20110082599 Shinde Apr 2011 A1
20110093281 Plummer Apr 2011 A1
20110095801 Bjerregaard et al. Apr 2011 A1
20110108724 Ewing May 2011 A1
20110185198 Ukita Jul 2011 A1
20110187542 Dittmer Aug 2011 A1
20110202193 Craig Aug 2011 A1
20110216453 Haines Sep 2011 A1
20110245988 Ingels Oct 2011 A1
20110260851 Richman Oct 2011 A1
20110270458 Liu Nov 2011 A1
20110273283 Schmuttor Nov 2011 A1
20110275960 Westerink Nov 2011 A1
20110316355 Gruber Dec 2011 A1
20120004871 Tsao Jan 2012 A1
20120022886 Ohnemus Jan 2012 A1
20120023555 Putterman Jan 2012 A1
20120025221 Sakumoto Feb 2012 A1
20120041917 Newton Feb 2012 A1
20120051714 Reimnitz Mar 2012 A1
20120082180 Edwardson Apr 2012 A1
20120086402 Carder Apr 2012 A1
20120087211 Lee et al. Apr 2012 A1
20120095610 Chapel Apr 2012 A1
20120098439 Recker et al. Apr 2012 A1
20120109398 Bhakta May 2012 A1
20120119714 Jitaru May 2012 A1
20120130544 Mohan May 2012 A1
20120154126 Cohn Jun 2012 A1
20120161969 Husen Jun 2012 A1
20120166642 Saint Clair et al. Jun 2012 A1
20120194082 Huang Aug 2012 A1
20120197196 Halbert Aug 2012 A1
20120206050 Spero Aug 2012 A1
20120209634 Ling Aug 2012 A1
20120229248 Parshionikar Sep 2012 A1
20120229278 Roosli Sep 2012 A1
20120258800 Mikhailov Oct 2012 A1
20120265361 Billingsley Oct 2012 A1
20120268136 Lee Oct 2012 A1
20120271471 Lee Oct 2012 A1
20120278101 Homchowdhury Nov 2012 A1
20120283860 Ho Nov 2012 A1
20120288124 Fejzo Nov 2012 A1
20120303554 Osann Nov 2012 A1
20120314344 Lam Dec 2012 A1
20120316661 Rahman Dec 2012 A1
20120319593 Jou Dec 2012 A1
20120325023 Calio Dec 2012 A1
20130006436 Masters Jan 2013 A1
20130013967 Gokhale et al. Jan 2013 A1
20130021720 Ty et al. Jan 2013 A1
20130024211 Monteforte Jan 2013 A1
20130035599 De Bruijn Feb 2013 A1
20130038470 Niemeyer Feb 2013 A1
20130049466 Adams Feb 2013 A1
20130049607 Urata Feb 2013 A1
20130051543 McDysan et al. Feb 2013 A1
20130058116 Galbas Mar 2013 A1
20130082817 Gruenbacher Apr 2013 A1
20130083805 Lu Apr 2013 A1
20130085609 Barker Apr 2013 A1
20130085615 Barker Apr 2013 A1
20130107041 Norem May 2013 A1
20130119891 Herremans May 2013 A1
20130135214 Li May 2013 A1
20130141233 Jacobs et al. Jun 2013 A1
20130144644 Simpson Jun 2013 A1
20130162821 Park Jun 2013 A1
20130166089 Craig Jun 2013 A1
20130174646 Martin Jul 2013 A1
20130175132 Battlogg Jul 2013 A1
20130184880 Mcmahon Jul 2013 A1
20130200254 Johnson Aug 2013 A1
20130201033 Cohn Aug 2013 A1
20130234625 Kondo Sep 2013 A1
20130238153 Warwick Sep 2013 A1
20130264889 Quittek Oct 2013 A1
20130271015 Peng Oct 2013 A1
20130275148 Attaluri Oct 2013 A1
20130289919 Wilson Oct 2013 A1
20130338839 Rogers Dec 2013 A1
20130339766 Chen Dec 2013 A1
20140006506 Frei Jan 2014 A1
20140025221 Chapel Jan 2014 A1
20140028097 Augur Jan 2014 A1
20140032003 Chapel Jan 2014 A1
20140035749 Reed Feb 2014 A1
20140046599 Smith Feb 2014 A1
20140052300 Matsuoka et al. Feb 2014 A1
20140069131 Masui Mar 2014 A1
20140070959 Bhargava et al. Mar 2014 A1
20140092765 Agarwal Apr 2014 A1
20140098445 Hooper Apr 2014 A1
20140099941 Ji Apr 2014 A1
20140100700 Matsumoto Apr 2014 A1
20140101346 Naaman Apr 2014 A1
20140122140 Rijnders et al. May 2014 A1
20140156084 Rahman Jun 2014 A1
20140185646 Mowry Jul 2014 A1
20140188286 Hunka Jul 2014 A1
20140233186 Savelli Aug 2014 A1
20140236372 Ewing Aug 2014 A1
20140257572 Mohan Sep 2014 A1
20140277869 King Sep 2014 A1
20140281544 Paczkowski Sep 2014 A1
20140283144 Gettings Sep 2014 A1
20140340227 Reed Nov 2014 A1
20140364089 Lienhart Dec 2014 A1
20150021465 Gettings Jan 2015 A1
Foreign Referenced Citations (5)
Number Date Country
1500955 Jan 2005 EP
2454731 May 2009 GB
WO-0133178 May 2001 WO
WO-2005063006 Jul 2005 WO
WO-2007148299 Dec 2007 WO
Non-Patent Literature Citations (75)
Entry
Albea, “High Performance Control Design for Dynamic Voltage Scaling Devices”, IEEE Transactions on Circuits and Systems, Part 1, Regular Papers 58, 12, Nov. 17, 2011, pp. 2919-2930.
Baran, Paul, “Packet Switching”, Fundamentals of Digital Switching, 2nd Ed., 1990, pp. 193-235.
Brown, Rick, “Nest pulls Protect Smoke Detector from Retail on Safety Issue”, CNET. Retrieved from the Internet: <www.cnet.com/news/nest-pulls-protect-smoke-detector-from-retail-on-safety-issue>, accessed on Nov. 3, 2014, 3 pgs.
Carriazo-Osorio, Fernando, “Impacts of Air Pollution on Property Values: An Economic Valuation for Bogota, Columbia”, Retrieved from the Internet: <http://www.demogr.mpg.de/papers/workshops/010518—paper02.pdf>, published on Aug. 19, 2007, 16 pgs.
“Chapter Five—Global Positioning System”, Global Positioning System. Retreived from the Internet: <http://www.academia.edu/6330277/Chapter—5—Global—Positioning—System>, pp. 5.1-5.14.
Fadell, Tony. “Consumer Safety Notice for Nest Protect: Smoke + CO Alarm”. Retrieved from the Internet: <Nest.com/letter-from-the-ceo>, published on Apr. 3, 2014, 3 pgs.
Dandamudi, Sivarama, “Interrupts”, Fundamentals of Computer Organization and Design, Sep. 22, 2001, pp. 825-862.
Dijkman, Greg, “Scientific Gel and Blot Imaging: The difference between resolution and sensitivity with CCD cameras.” Retrieved from the Internet: <gregdijkman.com/ccd-camera-imaging-sensitivity-resolution>, accessed on Nov. 5, 2014, 2 pgs.
“For $129, the best smoke detector on the market”, CNET. Retrieved from the Internet: <http://www.cnet.com/products/nest-protect>, accessed on Jul. 8, 2014, 4 pgs.
Frederiksen, Rikard, “The optical sensitivity of compound eyes: theory and experiment compared”, Bio. Lett., vol. 4, No. 6, Dec. 23, 2008, pp. 745-747.
“Guidance Regarding Methods for De-identification of Protected Health Information in Accordance with the Health Insurance Portability Act (HIPAA) Privacy Rule”, Department of Health and Human Services. Retrieved from the Internet: <http://www.hhs.gov/ocr/privacy/hippa/understanding/coveredentities/De-identification/guidance.html>, accessed on Dec. 4, 2014, 18 pgs.
Hayashi, et al., “A Network-Centric approach to Sensor-data and Service Integration”, SICE Annual Conference 2011, Sep. 13, 2011, pp. 2037-2042.
Huang, et al., “Pervasive, Secure Access to a Hierarchical Sensor-Based Healthcare Monitoring Architecture in Wireless Heterogeneous Networks”, IEEE Journal on Selected Areas in Communication, vol. 27, No. 4, May 2009, pp. 400-411.
Mainwaring, “Wireless Sensor Networks for Habitat Monitoring”, WNSA '02, Sep. 28, 2002, pp. 88-97.
McCracken, Harry, “Nest's Smoke Detector Recall; Doesn't Mean You Need to Send Yours Back”, Retrieved from the Internet: <http://time.com/108171/nest-recall/>, published on May 21, 2014, 2 pgs.
Miyaho, et al. “Sensor Network Management for Healthcare applications”, 2010 Fifth International Conference on Systems and Networks Communications, 2010, pp. 14-20.
Moffat, “Notes on Using Thermocouples”. Retrieved from the Internet: <http://www.electronics-cooling.com/1197/01/notes-on-using-thermocouples/>, accessed on Nov. 6, 2014, pp. 1-9.
Mogg, Trevor, “Nest Recall 440,000 Protect Smoke alarms, Issues Software Update that fixes Glitch”. Retrieved from the Internet: <http://www.digitaltrends.com/home/nest-halts-sales-of-nest-protect-smoke-alarm/>, published on May 21, 2014, 5 pgs.
“Nest Labs Recall to Repair Nest Protect Smoke + CO Alarms Due to Failure to Sound Alert”. Retrieved from the Internet: <http://www.cpsc/gov/en/Recalls/2014/Nest-Labs-Recalls-to-Repair-Nest-protect-Smoke-CO-Alarms>, published on May 21, 2014, 3 pgs.
“Nest Protect”, Manual, Oct. 2013, 2 pgs.
Noh, Sun-Kuh et al. “Design of a Room Monitoring System for Wireless Sensor Networks”, Intl. Journal of Distributed Sensor Networks, vol. 2013, Article ID 189840, 2013, 7 pages.
“Optical Resolution .” Retrieved from the Internet: <en.wikepedia.org/wiki.Optical—resolution>, accessed on Nov. 5, 2014, 11 pgs.
“Privacy Protector:6 Good Reasons to De-Indentify Data”. Retrieved from the Internet: <http://privacyguidance.com/blog/6-good-reasons-to-de-identify-data>, accessed on Dec. 8, 2014, 6 pgs.
“Resolution and Sensitivity”. Retrieved from the Internet: <www.atnf.csiro.au/outreach/education/senior/astrophysics/resolution—sensitivity.html>, accessed on Nov. 5, 2014, 5 pgs.
Steenerson, Christopher E, “Education in Microscopy and Digital Imaging”. Retrieved from the Internet: <zeiss-campus.magnets.fsu.edu/tutorials/basics/spatialfrequency/indexfalsh.html>, accessed on Nov. 5, 2014, 2 pgs.
“Symptom—Definition by Merriam-Webster”, Retrieved from the Internet: <http://www.merriam-webster.com/medical/symptom/>, accessed on Dec. 4, 2014, 3 pgs.
“Tutorial on Spatial Frequency Analysis”. Retrieved from the Internet: <www.psy.vanderbilt.edu/courses/hon185/SpatialFrequency/SpatialFrequency.html>, accessed on Nov. 5, 2014, 10 pgs.
“What is Nest Wave and how does it work?”. Retrieved from the Internet: <support/nest.com/article/what-is-nest-wave-and-how-does-it-work>, accessed on Nov. 5, 2014, 3 pgs.
Yildiz, “Potential ambient Energy-Harvesting Sources and Techniques”, The Journal of Technology Studies, vol. 35, No. 1. Fall 2009, pp. 1-14. Retrieved from the Internet: <http://scholar.lib.vt.edu/ejournals/JOTS/v351v35n1/yidliz.html>, accessed on Jan. 27, 2015.
U.S. Appl. No. 14/263,616, filed Apr. 28, 2014.
U.S. Appl. No. 14/263,668, filed Apr. 28, 2014.
U.S. Appl. No. 14/263,721, filed Apr. 28, 2014.
U.S. Appl. No. 14/283,075, filed May 20, 2014.
U.S. Appl. No. 14/640,738, filed Mar. 6, 2015.
U.S. Appl. No. 14/283,079, filed May 20, 2014.
U.S. Appl. No. 14/283,084, filed May 20, 2014.
U.S. Appl. No. 14/283,086, filed May 20, 2014.
U.S. Appl. No. 14/283,035, filed May 20, 2014.
U.S. Appl. No. 14/283,057, filed May 20, 2014.
U.S. Appl. No. 14/283,080, filed May 20, 2014.
U.S. Appl. No. 14/752,634, filed Jun. 26, 2015.
U.S. Appl. No. 14/283,097, filed May 20, 2014.
U.S. Appl. No. 14/316,446, filed Jun. 26, 2014.
U.S. Appl. No. 14/263,769, filed Apr. 28, 2014.
U.S. Appl. No. 14/263,802, filed Apr. 28, 2014.
U.S. Appl. No. 14/742,668, filed Jun. 17, 2015.
U.S. Appl. No. 14/263,838, filed Apr. 28, 2014.
U.S. Appl. No. 14/263,875, filed Apr. 28, 2014.
U.S. Appl. No. 14/263,899, filed Apr. 28, 2014.
U.S. Appl. No. 14/263,920, filed Apr. 28, 2014.
U.S. Appl. No. 14/535,249, filed Nov. 6, 2014.
U.S. Appl. No. 14/334,533, filed Jul. 17, 2014.
U.S. Appl. No. 14/334,550, filed Jul. 17, 2014.
U.S. Appl. No. 14/732,681, filed Jun. 6, 2015.
U.S. Appl. No. 14/334,567, filed Jul. 17, 2014.
U.S. Appl. No. 14/334,583, filed Jul. 17, 2014.
U.S. Appl. No. 14/334,598, filed Jul. 17, 2014.
U.S. Appl. No. 14/334,616, filed Jul. 17, 2014.
U.S. Appl. No. 14/448,849, filed Jul. 31, 2015.
U.S. Appl. No. 14/732,684, filed Jun. 6, 2015.
U.S. Appl. No. 14/467,872, filed Aug. 25, 2014.
U.S. Appl. No. 14/470,525, filed Aug. 27, 2014.
U.S. Appl. No. 14/470,753, filed Aug. 27, 2014.
U.S. Appl. No. 14/470,774, filed Aug. 27, 2014.
U.S. Appl. No. 14/732,683, filed Jun. 6, 2015.
U.S. Appl. No. 14/480,307, filed Sep. 8, 2014.
U.S. Appl. No. 14/848,195, filed Sep. 8, 2015.
U.S. Appl. No. 14/701,399, filed Apr. 30, 2015.
U.S. Appl. No. 14/701,410, filed Apr. 30, 2015.
U.S. Appl. No. 14/701,421, filed Apr. 30, 2015.
U.S. Appl. No. 14/701,435, filed Apr. 30, 2015.
U.S. Appl. No. 14/701,439, filed Apr. 30, 2015.
U.S. Appl. No. 14/701,445, filed Apr. 30, 2015.
U.S. Appl. No. 14/701,450, filed Apr. 30, 2015.
U.S. Appl. No. 14/701,451, filed Apr. 30, 2015.
Related Publications (1)
Number Date Country
20160113056 A1 Apr 2016 US