This non-provisional patent application claims priority to Great Britain applications: GB 1412720.3, filed Jul. 17, 2014; GB 1405790.5, filed Mar. 31, 2014; GB 1403314.6, filed Feb. 25, 2014; GB 1405785.5, filed Mar. 31, 2014; GB 1405786.3, filed Mar. 31, 2014; GB 1405789.7, filed Mar. 31, 2014; GB 1403312.0, filed Feb. 25, 2014; GB 1405791.3, filed Mar. 31, 2014; GB 1405797.0, filed Mar. 31, 2014.
This invention relates to determining the proximity of a wireless communications device.
There is an increasing need for a variety of objects to be equipped with the ability to send and receive messages. In the case of a home, for example, it may be desired that the objects in a room be capable of communicating with each other, and also potentially to be able to communicate with the internet or cloud. For example, the room may have a light, light switch, window and door. It may be desired that each of these objects be able to communicate with the others so that the home can be automated.
To enable objects to communicate, they may be equipped with a communication device that can communicate with similar communication devices attached to other objects. For this type of architecture, a large number of objects may be able to communicate with each other. The result can be a network of many communication devices, each associated with a respective object. As many of these objects may not have access to, or require, power themselves (for example, a window, door, packages sitting on a shelf, etc), there may be a desire for the devices that communicate on the objects' behalf to be battery-powered devices that consume only a small amount of power. It may also be desirable that these devices be able to communicate wirelessly with each other so that there is no need for cables running between them.
One suitable method of communication for such a network is to use a mesh networking protocol. This permits a first device to send a message to a second device, which may be outside the communication range of the first device, by transmitting the message via one or more intermediate devices. Historically, mesh networking protocols are typically designed around the concept of devices sending messages using complex routing tables. Such complex routing requires processing power which tends to increase power consumption of the devices. Such mesh networking protocols also tend to operate according to proprietary protocols. This means devices have to be manufactured specifically for the task of communicating according to a particular mesh network. This may be undesirable because it increases the cost of devices that might be installed in a multitude locations and/or attached to a multitude of different devices.
It can be advantageous to control some behavioural aspects of a device connected to the mesh network. Some aspects of their behaviour could be changed, for example, in dependence on their surrounding environment. For example, it may be useful to have lights that are connected to the mesh network to be able to automatically switch themselves on or off as a user moves around a building. In another example, it may be useful for the mesh network to maintain a certain level of service that ensures messages can get from one device to another device even if some intermediate relaying devices are running low on power and less capable of relaying message. In those examples, it may be useful to have knowledge of the location (absolute or relative to other devices) of the mesh devices so that their behaviour can be appropriately controlled. Thus there is a need for a method of determining the proximity of devices to other devices in a mesh network.
According to a first aspect there is provided a method of determining the proximity of a first device to a second device, the method comprising, at the second device: receiving a first packet having a first payload and a first lifetime value, the first lifetime value being such so as to cause a device receiving the first packet to not retransmit the first payload; and generating, in dependence on the first packet, a second packet having a second payload and a second lifetime value, the second payload being indicative of the proximity of the first device to the second device and the second lifetime value being such so as to cause a device receiving the second packet to retransmit the second payload.
The payload of the second packet may comprise an identifier for the first device, an identifier for the second device and said indication of the proximity.
The second device may be configured to instruct one or more other devices to perform an action in dependence on said proximity indication.
The first and second devices may be in a network of devices comprising a third device, the method may further comprise, at the third device, receiving and analysing the first packet and a packet comprising said instruction and in dependence on said analysis, disregarding the instruction. At the third device and on disregarding the instruction, the method may further comprise generating and transmitting a third packet comprising a message indicating that the instruction has been disregarded.
The second packet may be generated in dependence on the proximity indication being above a predetermined proximity threshold.
The second packet may be generated in dependence on said proximity indication being below a predetermined proximity threshold and on not receiving a packet indicating the proximity of the first device to another device for a predetermined duration of time from receiving the first packet.
The method may further comprise, at the second device: receiving a third packet having a third payload and a third lifetime value in dependence on the first packet, the third payload being indicative of the proximity of the first device to a third device and the third lifetime value being such so as to cause a device receiving the third packet to retransmit the third payload; and processing the third payload so as to compare the indicated proximity of the first device to the third device with the indicated proximity of the first device with the second device. The method may further comprise, at the second device, generating and broadcasting a fourth packet in dependence on said comparison, the fourth packet comprising a payload configured to cause another device to perform a first action. The method may further comprise, at the second device, performing a second action in dependence on said comparison.
The first and second devices may be in a network of devices comprising a third device, the method may further comprise, at a third device: receiving the first packet comprising an identifier for the first device; and determining whether or not to generate a third packet in dependence on whether or not the third device receives the second packet, the third packet having a third payload and a third lifetime value in dependence on the first packet, the third payload being indicative of the proximity of the first device to the third device and the third lifetime value being such so as to cause a device receiving the third packet to retransmit the third payload.
The method may further comprise, at the second device, measuring a characteristic of the received first packet, said characteristic being at least one of signal strength, signal round-trip time, signal arrival time, signal quality and signal error.
The first and second devices may be capable of communicating in a mesh network.
The first and second devices may be capable of operating according to a wireless communications protocol, which defines a broadcast packet type. The method may further comprise, at the second device: receiving a first broadcast packet of the broadcast packet type, the broadcast packet comprising the first packet; and broadcasting a second broadcast packet of the broadcast packet type, the second broadcast packet comprising the second packet. The wireless communication protocol may be Bluetooth low energy.
According to a second aspect, there is provided a wireless communication device comprising: a transceiver configured to receive, from a first device, a first packet having a first payload and a first lifetime value, the first lifetime value being such so as to cause a device receiving the first packet to not retransmit the first payload; a processor configured to process the first packet and generate, in dependence on the first packet, a second packet having a second payload and a second lifetime value, the second payload being indicative of the proximity of the first device to the wireless communication device and the second lifetime value being such so as to cause a device receiving the second packet to retransmit the second payload.
According to a third aspect, there is provided a communications system comprising: a first device being configured to transmit a first packet having a first payload and a first lifetime value, the first lifetime value being such so as to cause a device receiving the first packet to not retransmit the first payload, and a second device being configured to receive the first packet and generate, in dependence on the first packet, a second packet having a second payload and a second lifetime value, the second payload being indicative of the proximity of the first device to the second device and the second lifetime value being such so as to cause a device receiving the second packet to retransmit the second payload.
The communications system may comprise a plurality of wireless nodes within a predetermined area and forming a mesh network, each node being associated with a region within said area, the second device being one of the plurality of wireless nodes, a particular node of the plurality of wireless nodes being configured to receive the second packet and perform an action in dependence on the second packet and the region associated with the particular node. The communications system may further comprise a management device capable of communicating in the mesh network, the management device configured to generate and transmit a third packet having a payload capable of causing devices associated with a particular region to perform a particular action.
The present invention will now be described by way of example with reference to the accompanying drawings. In the drawings:
The following description is presented to enable any person skilled in the art to make and use the invention, and is provided in the context of a particular application. Various modifications to the disclosed embodiments will be readily apparent to those skilled in the art.
The general principles defined herein may be applied to other embodiments and applications without departing from the spirit and scope of the present invention. Thus, the present invention 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.
The present disclosure relates to wireless communication devices that are capable communicating as part of a mesh network, which operates according to a mesh protocol. In the examples described herein, the devices are capable of operating according to a mesh protocol that is implemented using a wireless communications protocol (e.g. such as Bluetooth low energy (BLE)). The operation of the devices according to a mesh protocol is described in the following paragraphs.
The devices are capable of communicating according to a wireless communications protocol that defines a broadcast packet type. The broadcast packet type is not defined by the wireless communications protocol as being addressed to any one particular device. This is because the broadcast packet type is transmitted according to a wireless communication protocol that is blind to the existence of the network structure that is present at the transport layer within the mesh network.
The mesh network is not defined by the wireless communication protocol. The wireless communication device uses the broadcast packet type according to the wireless communication protocol to send mesh network data packets. The mesh network data packets are suitably transport layer data packets. When the wireless communication device receives a data packet of the broadcast packet type, it checks whether the payload includes a mesh data packet. If so, it may check whether the mesh network data packet has been previously been received by the wireless communication device. If the packet has been previously received by the wireless communication device it can decide not to retransmit the mesh data packet. If the packet has not been previously received by the wireless communication device then, it checks a lifetime value of the mesh data packet to see if it is equal to a predetermined threshold value. If the lifetime value is not equal to the predetermined threshold value, then the device retransmits the mesh data packet within a broadcast packet type data packet. When retransmitting, the only portion of the mesh data packet that is altered is the lifetime value so that it reflects the fact that the packet has been received and retransmitted. Thus the payload of the mesh data packet is left unaltered when retransmitted. If the lifetime value is equal to the predetermined threshold value, however, the communication device does not retransmit the mesh data packet.
The packet 400 may be comprised within the payload of a broadcast packet, which may, for example be a Bluetooth low energy non-connectable undirected advertising packet. Packet 400 may be a mesh transport layer packet, which a device can process at the transport layer to enable the retransmission of the message throughout a network.
The higher layer message field 410 can comprise a message that is generated by one device to be sent to one or more other devices. The contents of the higher layer message may be intended for processing at a layer higher than the transport layer (e.g. at the application level) and so it may be opaque to the transport layer. The higher level message field 410 may comprise the ID of the sender and a serial number. The serial number can be unique to that particular sender. The pair of the sender-ID and the serial number can be used to uniquely identify a particular message within the mesh network. The higher layer message 410 may be considered to be the payload of the packet as it contains the information that is purpose of the transmission of the packet. For example, a light switch that is mesh device may wish to instruct a light that is also a mesh device to turn on and thus may generate an appropriate message for that light at an application layer. Packet 400 may then be formed with the application layer message being within the contents of the higher layer message 410. The payload of the mesh transport packet 400 can also be described as the static content of the mesh transport packet 400 because it is not altered as it is retransmitted throughout the mesh network.
The packet 400 may comprise a MAC 420 field that can be used to identify and authenticate the packet. The MAC may be computed based on the contents of the higher layer message field 410.
The TTL field 430 can generally be described as a lifetime field 430 that defines the lifetime of the mesh transport packet 400 within the mesh network. The lifetime field 430 of the mesh transport packet 400 can be used by a receiving device to determine whether the received mesh transport packet 400 should be retransmitted or not. When a device retransmits a packet 400, the device retransmits the packet with fields 410 and 420 identical to that of the content of the packet as it received it, except that it decrements the TTL value, e.g. by one. Each device is configured not to retransmit any mesh packets it receives with a TTL of zero. In that way the TTL serves to prevent messages circulating indefinitely in the mesh network. With this behaviour in mind, the original value of the TTL can be set depending on the properties of the network. A large or unreliable network may require a larger initial TTL value than a smaller, more reliable network. In other implementations the TTL could be interpreted in other ways: for example it could be incremented up to a pre-set limit at each retransmission.
In some situations, it can be desirable for devices in a mesh network (that can operate as described above) to be able to influence the behaviour and actions of other devices in the network. For some actions, it can be useful for a device to know about its surroundings and about its neighbouring devices. For example, as described in the example above, it can be useful for a group of mesh devices such as light bulbs to be able to determine the location of a user so that the light bulbs in the same room as the user can be switched on and the bulbs in other rooms can be switched off. The user may carry a device (such as a smartphone) that is capable communicating with devices in the mesh network. As described in more detail below, this would allow the mesh devices to detect the presence of the user in their surrounding environment and change their behaviour (and influence the behaviour of other devices) accordingly.
In another example, it can be useful for a mesh device that is in a fixed location to have knowledge of other neighbouring fixed mesh devices so that it can adjust its ability to retransmit mesh packets in accordance with the number of (and, preferably, reliability of) its neighbouring devices. This can help ensure that mesh packets are propagated throughout the network.
A smartphone 260 may also be part of the mesh network 300 or capable of being detected by devices in the mesh network 300. The smartphone 260 may be portable and when it comes within range of a device in network 300, it may be detected, which can lead to devices in the network to perform certain actions, as described further below.
Some of the devices in the mesh network 300 may be in fixed physical locations and have regions associated with them. For example, lights 110, 120, 130, 140, 150, fan 160 and light switch 170 may be associated with a region, such as a first room 100 and lights 210, 220, 240, 250 and light switch 270 may be associated with another region, such as a second room 200. The region that a device belongs to may be stored at that device and/or at a mesh network management device such as the smartphone 260 and/or a server (not shown) that is capable of receiving and sending mesh messages (which may be done via a bridge, as described above with respect to
A portable device, such as smartphone 260, may not be associated with a region as it able to move to various locations. The smartphone 260 may be configured to operate in a mode which enables its proximity to other mesh devices to be determined. The smartphone 260 can be configured to periodically transmit a “proximity event” packet, which is a mesh packet that has a TTL at a predetermined value (e.g. zero). As mentioned above, any mesh device that receives a mesh packet that has a TTL of zero it will not retransmit that packet. The proximity event packet may have a payload that comprises information such as an identifier for the smartphone 260 and/or an indication of packet type, such as a proximity event packet type. This allows mesh devices that receive the proximity event packet to determine that the smartphone 260 is physically located near to those devices. For example, light 250 may be within transmission range of the smartphone 260 and able to receive the proximity event packet. As the proximity event packet has a TTL of zero and the payload comprises information that indicates its packet type, the light 250 is able to determine that the packet was directly received from the smartphone 260 and it was not relayed via another mesh device. Thus the light 250 is able to determine that the smartphone 260 is nearby.
In response to receiving the proximity event packet, the light 250 can then generate and transmit a “proximity report” packet. This packet can let the other devices in the mesh network 100 know that the light 250 is near to the smartphone 260. So that the proximity report can be sent to the other devices in the mesh network, the TTL has a value that is greater than one so that it can be retransmitted by at least one device. The proximity report packet can comprise a payload having information such as an identifier for the smartphone 260, an identifier for light 250, the region associated with the light (e.g. a group identifier), an indication of the proximity of the smartphone 260 to the light 250 and/or other information.
In some cases, a device may decide not to generate and transmit a proximity report in response to receiving a proximity event packet. This may be the case when, for example, the device has previously received a proximity event packet and has recently sent a proximity report having the same or similar information. Thus, a mesh device may be configured to transmit proximity reports in dependence on previous reports that it has transmitted. This is would help avoid flooding the mesh network with proximity reports.
The proximity report from light 250 may reach switch 170 (e.g. via relaying by lights 220, 130 and 150) which can control the lights in room 100. The switch 170 may be able to access and process the payload of the proximity report to allow it to determine that the smartphone 260 is near to light 250. The switch 170 may be configured to perform an action on the basis of this information. For example, the switch 170 is associated with room 100 and it determines that the smartphone is in room 200 because light 250 is associated with that room, and thus the switch 170 decides to turn from on to off (or remain off) so that the lights in room 100 are switched off.
In another example, devices 220 and 250 may both receive a proximity event packet from the smartphone 260 (from the same transmission by the smartphone 260 or transmissions at different times). Devices 220 and 250 may each be capable of determining a measure of proximity from the device 220 or 250 to the smartphone 260 by receiving the proximity event. The devices 220 and 250 may be able to form a measure of the proximity by, for example, measuring the signal strength (e.g. RSSI) of the received proximity event. Other measures may be used such as signal phase, signal quality and/or signal error of the received proximity event. The devices 220 and 250 could also respond to the proximity event message so that signal roundtrip time can be determined as a way of measuring the proximity.
Device 220 then generates and transmits its proximity report and so does device 250. The devices 220 and 250 then receive each other's reports (e.g. directly from each other or relayed via another device, e.g. smartphone 260). Device 220 can then compare the RSSI contained in the proximity report from light 250 with the RSSI determined from the proximity event from the smartphone 260 and determine if it is closer to or further from the smartphone 260 than light 250. Light 250 can also carry out a similar comparison. If, for example, light 220 determines that it is closer to the smartphone 260 than light 250, then it may switch itself (or remain) on. Correspondingly, light 250 may determine that it is further than light 220 and switch itself (or remain) off. Alternatively, rather than light 250 automatically switching itself off, light 220 can generate and send a mesh packet that instructs light 250 to switch off.
Further devices, such as switch 270, light 210, etc may also detect the proximity event from the smartphone 260 and then each send their proximity reports. The proximity reports can be processed and/or relayed by other devices in the mesh network 300. In this way, devices in the network 300 can collate the information in the proximity reports and learn the proximity of other devices to the smartphone 260. Based on this collated information, the devices may carry out actions. For example, light 210 may collate reports from lights 220, 240, 250 and compare the RSSIs for each of those lights. Based on this, light 210 may, for example, determine that it has the highest RSSI and therefore it is the closest light to smartphone 260. Light 210 may then transmit a packet that instructs the other lights to switch off. Light 220, however, may also have collated the RSSIs of lights 220, 240, 250 as well as 210 and its own RSSI value. From this, light 220 may determine that it is closer to smartphone 260 than light 210. Thus, when light 220 receives the packet that originated from light 210 that instructs the lights to switch off, light 220 can disregard this instruction and turn itself (or remain) on. Light 220 can then respond to the instruction informing the other lights that the instruction was disregarded and that light 220 is in fact the closest and thus light 210 will turn itself off when it receives the response.
A device may be configured to generate a proximity report if the proximity indication derived from the proximity event packet is above a predetermined threshold. For example, light 130 may receive the proximity event from smartphone 260. From the received proximity event, a weak RSSI may be determined. Thus, the light 130 may decide that it is not to generate a proximity report. The decision may be based on the RSSI not meeting a predetermined RSSI threshold level. In some circumstances, the light 130 may decide later that it is to generate and transmit the proximity report. For example, if the light 130 does not receive a proximity report from another device that indicates the proximity of the smartphone 260 to that other device, then the devices in the mesh network may not be aware of the presence of the smartphone 260. Thus, even if the RSSI threshold is not met, the light 130 may wait for a predetermined amount of time to see if it receives any other proximity reports and if it doesn't, then it can generate and send a proximity report for the smartphone 260. The predetermined waiting time may be dependent on the number of mesh devices surrounding each device. For example, if surrounded by a relatively low number of devices, mesh packets may take longer to reach a device and thus the predetermined time should be longer compared to a device that was surrounded by a relatively high number of devices.
A device may select a RSSI threshold level in dependence on the number and/or proximity of neighbouring devices. For example, a large area may comprise a relatively small amount of mesh devices and thus the RSSI threshold may be lowered for those devices to effectively increase their “detection area” so that when a portable device that broadcasts the mesh event packets enters that area it's presence and proximity can be detected, which is then reported to other mesh devices. On the other hand, a small area comprising a relatively large amount of mesh devices would benefit from an RSSI threshold that is higher for those devices. This would act to limit the number of proximity reports generated, transmitted and relayed throughout the mesh network, thus saving power throughout the mesh.
A device may use the proximity event and proximity report packets to determine which other mesh devices are located proximate to that device. This way, the fixed devices can determine the density of devices around them and report that determination to other devices. Devices may set or adjust its RSSI threshold or predetermined waiting time depending on this determination. Devices which have a fixed physical location may allow other devices to determine their surroundings by transmitting the proximity event packet on initialisation, periodically or upon instruction. Proximity reports generated in response to receiving a proximity event packet can then be shared with other devices so that each device may be able to determine a local or regional topology.
Proximity reports that are generated and transmitted as a result of portable and/or fixed devices transmitting proximity event packets may be received at a mesh network management device which can collate the reports to determine a global topology that provides a relative measure of the proximity of each mesh device relative to other mesh devices. Each proximity report maybe considered to be partial information about the topology of the network. By collating and processing increasing numbers of proximity reports from various sources, a more detailed and accurate global topology can be determined.
In one alternative example, information about the topology of a mesh network could be determined by observing how a proximity event message with a low TTL value (e.g. one or two) propagates throughout the network.
Proximity reports generated in response to directly or indirectly receiving the proximity event messages could be collated by the network management device and processed to determine topology information. Based on the topology information, the mesh management device may determine actions that are to be carried out by some or all of the devices in the mesh network. For example, the mesh management device may optimise the amount of power consumed by each device in the mesh whilst listening for mesh messages by analysing the topography information to determine an optimal listening time for each device and then sending instructions to each device to adjust its listening time.
The mesh network management device may be a device such as the smartphone which is physically located in the region of the mesh devices or it may be a server that is located outside the coverage area of the mesh network and is able to send and receive mesh message via a bridge (as described above with respect to
As mentioned above, receiving a proximity event packet provides an indication of proximity of the transmitting device to the receiving device. This indication may be that the transmitting device is present somewhere in a particular area (e.g. in a particular part of a building). By measuring characteristics of the signal from the transmission of the proximity event packet, further information may be derived. E.g. a device may measure RSSI to estimate the distance between the transmitting and receiving devices.
The RSSI value or a distance calculation from the RSSI value could be used to determine how close a transmitting device is to the receiving device. Multiple devices may measure the RSSI and share those measurements (via proximity reports) to help trilaterate the location of the transmitting device.
Additional proximity information from other sources (e.g. detecting Wi-Fi access points, etc) could be combined with the proximity information from the proximity event packet and sent to other mesh devices in the proximity report packet.
One or more devices in the mesh network (e.g. the smartphone 260) may be capable of providing information that may be used to determine its absolute location, for example, an image of a bar-code indicating location, information from a Global Navigation Satellite System (GNSS), a location obtained by triangulating signals from cell-phone transmitters, or information manually provided by a user such as a position on a map. The absolute location information may be combined with the relative proximity information that is determined from proximity reports so that absolute locations of other mesh devices can be estimated.
As mentioned above, each of the objects (lights, switches, etc) comprises a wireless communication device that enables the object to communicate over a wireless communications protocol.
The processor 503 can be a microprocessor. The memory 504 may be part of processor 503 or connected to processor 503 via a bus. Whilst the processor 503 and transceiver 502 are shown in
The device 500 may also comprise a power source (not shown). The power source may be a battery. Alternatively, the device 500 may not comprise a power source and be connected to an external power source such as an electrical outlet.
The communication device also comprises an interface 505 for sending and receiving data that is sent and received using the communications protocol. A higher layer entity, e.g. an object controller, which may be an application, can provide higher layer message data via the interface 505 for sending via the protocol. Higher layer message data from a received packet can be provided to, e.g. the controller, via the interface 505. The interface 505 may be a wired link. The wired link may be to sensors for sensing external events, such as the operation of a light switch in the home environment described above, or a link to appliances for issuing control signals to those appliances, such as the light in the home environment described above.
The devices described herein may be wireless communication devices that operate according to the same wireless communication protocol. The wireless communication protocol could be a relatively short-range protocol. For example the effective range of each device could be less than 25 m. That characteristic can permit the devices to use less power for transmitting and/or receiving than would be expected in a longer range protocol. In one example, the devices could operate according to the Bluetooth protocol, specifically the Bluetooth Low Energy (BLE) protocol. The devices could use other protocols, for instance IEEE 802.11 or ZigBee.
The devices described herein may comprise secondary communication interface that supports a different, second, physical and/or logical communications protocol from the one that is used for communicating over the mesh network. Examples of the protocols that could be supported by the secondary communication interface include wireless protocols such as those mentioned above and also wired protocols such as Ethernet, USB or HomePlug.
The devices described herein could form a mesh network with other wireless communication devices. The devices could be configured to forward some or all messages they receive. The messages could be sent and received via a broadcast packet type defined in the wireless communication protocol. All the devices in the network could be peers in that they have identical roles at a network level.
The devices configured in accordance with the examples described herein could be embodied in hardware, software or any suitable combination of hardware and software. The receiving device of the examples described herein could comprise, for example, software for execution at one or more processors (such as at a CPU and/or GPU), and/or one or more dedicated processors (such as ASICs), and/or one or more programmable processors (such as FPGAs) suitably programmed so as to provide functionalities of the data processing system, and/or heterogeneous processors comprising one or more dedicated, programmable and general purpose processing functionalities. In the examples described herein, the devices comprise one or more processors and one or more memories having program code stored thereon, the data processors and the memories being such as to, in combination, provide the claimed data processing systems and/or perform the claimed methods.
Data processing units described herein (e.g. processor 503) need not be provided as discrete units and represent functionalities that could (a) be combined in any manner, and (b) themselves comprise one or more data processing entities. Data processing units could be provided by any suitable hardware or software functionalities, or combinations of hardware and software functionalities.
Any one or more of the methods described herein could be performed by one or more physical processing units executing program code that causes the unit(s) to perform the data processing methods. Each physical processing unit could be any suitable processor, such as a CPU or GPU (or a core thereof), or fixed function or programmable hardware. The program code could be stored in non-transitory form at a machine readable medium such as an integrated circuit memory, or optical or magnetic storage. A machine readable medium might comprise several memories, such as on-chip memories, computer working memories, and non-volatile storage devices.
The applicant hereby discloses in isolation each individual feature described herein and any combination of two or more such features, to the extent that such features or combinations are capable of being carried out based on the present specification as a whole in the light of the common general knowledge of a person skilled in the art, irrespective of whether such features or combinations of features solve any problems disclosed herein, and without limitation to the scope of the claims. The applicant indicates that aspects of the present invention may consist of any such individual feature or combination of features. In view of the foregoing description it will be evident to a person skilled in the art that various modifications may be made within the scope of the invention.
Number | Date | Country | Kind |
---|---|---|---|
1403312.0 | Feb 2014 | GB | national |
1403314.6 | Feb 2014 | GB | national |
1405785.5 | Mar 2014 | GB | national |
1405786.3 | Mar 2014 | GB | national |
1405789.7 | Mar 2014 | GB | national |
1405790.5 | Mar 2014 | GB | national |
1405791.3 | Mar 2014 | GB | national |
1405797.0 | Mar 2014 | GB | national |
1412720.3 | Jul 2014 | GB | national |
Number | Name | Date | Kind |
---|---|---|---|
6917974 | Stytz et al. | Jul 2005 | B1 |
6986046 | Tuvell et al. | Jan 2006 | B1 |
7522540 | Maufer | Apr 2009 | B1 |
7778270 | Zhang et al. | Aug 2010 | B1 |
7787427 | Simon et al. | Aug 2010 | B1 |
8495618 | Inbaraj et al. | Jul 2013 | B1 |
8516269 | Hamlet et al. | Aug 2013 | B1 |
8681671 | Hui et al. | Mar 2014 | B1 |
8938792 | Koeberl et al. | Jan 2015 | B2 |
8953790 | Qi et al. | Feb 2015 | B2 |
20020119770 | Twitchell | Aug 2002 | A1 |
20030014507 | Bertram et al. | Jan 2003 | A1 |
20030037237 | Baldwin et al. | Feb 2003 | A1 |
20030163554 | Sendrowicz | Aug 2003 | A1 |
20030181203 | Cheshire | Sep 2003 | A1 |
20040246911 | Bonsma et al. | Dec 2004 | A1 |
20050036469 | Wentink | Feb 2005 | A1 |
20050113102 | Kwon et al. | May 2005 | A1 |
20050175184 | Grover et al. | Aug 2005 | A1 |
20050246533 | Gentry | Nov 2005 | A1 |
20050249137 | Todd et al. | Nov 2005 | A1 |
20060025180 | Rajkotia et al. | Feb 2006 | A1 |
20060034233 | Strutt et al. | Feb 2006 | A1 |
20060041653 | Aaron | Feb 2006 | A1 |
20060135064 | Cho et al. | Jun 2006 | A1 |
20060154598 | Rudland et al. | Jul 2006 | A1 |
20060156390 | Baugher | Jul 2006 | A1 |
20060209584 | Devadas et al. | Sep 2006 | A1 |
20060212938 | Suzuki | Sep 2006 | A1 |
20060245424 | Ramanathan et al. | Nov 2006 | A1 |
20060268742 | Chu | Nov 2006 | A1 |
20060268749 | Rahman et al. | Nov 2006 | A1 |
20070025274 | Rahman | Feb 2007 | A1 |
20070097895 | Keshavarzian et al. | May 2007 | A1 |
20070105542 | Friedman | May 2007 | A1 |
20070110024 | Meier | May 2007 | A1 |
20070127421 | D'Amico et al. | Jun 2007 | A1 |
20070206537 | Cam-Winget et al. | Sep 2007 | A1 |
20070211654 | Kim et al. | Sep 2007 | A1 |
20070211736 | Sapek et al. | Sep 2007 | A1 |
20070247303 | Payton | Oct 2007 | A1 |
20070280136 | Chen | Dec 2007 | A1 |
20070280137 | Bahr et al. | Dec 2007 | A1 |
20070281721 | Lee et al. | Dec 2007 | A1 |
20080013947 | Peloso et al. | Jan 2008 | A1 |
20080069030 | Hirano et al. | Mar 2008 | A1 |
20080095059 | Chu et al. | Apr 2008 | A1 |
20080205385 | Zeng et al. | Aug 2008 | A1 |
20080279155 | Pratt, Jr. et al. | Nov 2008 | A1 |
20080291855 | Bata | Nov 2008 | A1 |
20080292105 | Wan et al. | Nov 2008 | A1 |
20090054033 | Pratt, Jr. | Feb 2009 | A1 |
20090067373 | Kneckt et al. | Mar 2009 | A1 |
20090089408 | Bou-Diab | Apr 2009 | A1 |
20090216349 | Kwon et al. | Aug 2009 | A1 |
20090222659 | Miyabayashi et al. | Sep 2009 | A1 |
20090232037 | Dixit et al. | Sep 2009 | A1 |
20090274173 | Wentink | Nov 2009 | A1 |
20090279518 | Falk et al. | Nov 2009 | A1 |
20090307483 | Falk et al. | Dec 2009 | A1 |
20090312023 | Kazmi | Dec 2009 | A1 |
20100005294 | Kostiainen et al. | Jan 2010 | A1 |
20100046439 | Chen et al. | Feb 2010 | A1 |
20100061272 | Veillette | Mar 2010 | A1 |
20100100940 | Reynolds | Apr 2010 | A1 |
20100141406 | Jo et al. | Jun 2010 | A1 |
20100149028 | Mermet et al. | Jun 2010 | A1 |
20100191968 | Patil et al. | Jul 2010 | A1 |
20100202345 | Jing et al. | Aug 2010 | A1 |
20100205281 | Porter et al. | Aug 2010 | A1 |
20100208621 | Morper | Aug 2010 | A1 |
20100241857 | Okude et al. | Sep 2010 | A1 |
20100246460 | Kholaif et al. | Sep 2010 | A1 |
20100260146 | Lu | Oct 2010 | A1 |
20100262828 | Brown et al. | Oct 2010 | A1 |
20110003547 | Oh et al. | Jan 2011 | A1 |
20110053493 | Yanagihara | Mar 2011 | A1 |
20110081860 | Brown et al. | Apr 2011 | A1 |
20110099368 | Koh | Apr 2011 | A1 |
20110121654 | Recker et al. | May 2011 | A1 |
20110128884 | Reynaud et al. | Jun 2011 | A1 |
20110149999 | Kamito et al. | Jun 2011 | A1 |
20110164512 | Citrano, III et al. | Jul 2011 | A1 |
20110216695 | Orth | Sep 2011 | A1 |
20120087290 | Rhee et al. | Apr 2012 | A1 |
20120087292 | Grimm et al. | Apr 2012 | A1 |
20120163292 | Kneckt et al. | Jun 2012 | A1 |
20120182860 | Liu et al. | Jul 2012 | A1 |
20120195231 | Fonseca et al. | Aug 2012 | A1 |
20120196534 | Kasslin et al. | Aug 2012 | A1 |
20120198434 | Dirstine et al. | Aug 2012 | A1 |
20120198435 | Dirstine et al. | Aug 2012 | A1 |
20120252405 | Lortz et al. | Oct 2012 | A1 |
20120263072 | Wu | Oct 2012 | A1 |
20130016654 | Mayo et al. | Jan 2013 | A1 |
20130029685 | Moshfeghi | Jan 2013 | A1 |
20130051552 | Handschuh et al. | Feb 2013 | A1 |
20130064175 | Pandey et al. | Mar 2013 | A1 |
20130065584 | Lyon et al. | Mar 2013 | A1 |
20130067222 | Munger et al. | Mar 2013 | A1 |
20130070745 | Nixon et al. | Mar 2013 | A1 |
20130080765 | Mohanty et al. | Mar 2013 | A1 |
20130107909 | Jones et al. | May 2013 | A1 |
20130128809 | Wentink et al. | May 2013 | A1 |
20130130622 | Yang et al. | May 2013 | A1 |
20130198305 | Veillette | Aug 2013 | A1 |
20130215900 | Jogadhenu | Aug 2013 | A1 |
20130219482 | Brandt | Aug 2013 | A1 |
20130227336 | Agarwal | Aug 2013 | A1 |
20130242929 | Goergen et al. | Sep 2013 | A1 |
20130279409 | Dublin, III et al. | Oct 2013 | A1 |
20130279410 | Dublin, III | Oct 2013 | A1 |
20130301471 | Brown | Nov 2013 | A1 |
20140025806 | Robitaille | Jan 2014 | A1 |
20140044016 | Rahman | Feb 2014 | A1 |
20140047260 | Iijima | Feb 2014 | A1 |
20140064261 | Wang et al. | Mar 2014 | A1 |
20140089912 | Wang et al. | Mar 2014 | A1 |
20140108786 | Kreft | Apr 2014 | A1 |
20140111234 | Laackmann et al. | Apr 2014 | A1 |
20140112470 | Shen et al. | Apr 2014 | A1 |
20140167912 | Snyder et al. | Jun 2014 | A1 |
20140169174 | Gilson | Jun 2014 | A1 |
20140171062 | Fallgren | Jun 2014 | A1 |
20140181172 | Elliott | Jun 2014 | A1 |
20140189790 | Mindler et al. | Jul 2014 | A1 |
20140266669 | Fadell et al. | Sep 2014 | A1 |
20140337607 | Peterson et al. | Nov 2014 | A1 |
20150010153 | Robertson | Jan 2015 | A1 |
20150019892 | Agrawal et al. | Jan 2015 | A1 |
20150052351 | Nodehi Fard Haghighi et al. | Feb 2015 | A1 |
20150058409 | Wang | Feb 2015 | A1 |
20150121108 | Agrawal et al. | Apr 2015 | A1 |
20150143130 | Ducharme et al. | May 2015 | A1 |
20150195692 | Chow et al. | Jul 2015 | A1 |
20150242614 | Scagnol et al. | Aug 2015 | A1 |
20150244481 | Tyson et al. | Aug 2015 | A1 |
20150244484 | Tyson et al. | Aug 2015 | A1 |
20150244565 | Heydon | Aug 2015 | A1 |
20150244623 | Heydon et al. | Aug 2015 | A1 |
20150244648 | Tyson et al. | Aug 2015 | A1 |
20150244828 | Heydon | Aug 2015 | A1 |
20150245179 | Jarvis et al. | Aug 2015 | A1 |
20150245182 | Scagnol et al. | Aug 2015 | A1 |
20150245203 | Tyson et al. | Aug 2015 | A1 |
20150245204 | Heydon | Aug 2015 | A1 |
20150245220 | Williamson et al. | Aug 2015 | A1 |
20150245296 | Tyson et al. | Aug 2015 | A1 |
20150245351 | Banerjea et al. | Aug 2015 | A1 |
20150245369 | Heydon | Aug 2015 | A1 |
20150245412 | Tyson et al. | Aug 2015 | A1 |
20150326444 | Smith | Nov 2015 | A1 |
Number | Date | Country |
---|---|---|
102761941 | Oct 2012 | CN |
102984798 | Mar 2013 | CN |
1496668 | Jan 2005 | EP |
1780951 | May 2007 | EP |
1886450 | Feb 2008 | EP |
2306692 | Apr 2011 | EP |
2464125 | Apr 2010 | GB |
2007124148 | May 2007 | JP |
02078272 | Oct 2002 | WO |
03026224 | Mar 2003 | WO |
2004004230 | Jan 2004 | WO |
WO-2004104850 | Dec 2004 | WO |
2007013914 | Feb 2007 | WO |
2008004102 | Jan 2008 | WO |
2008013878 | Jan 2008 | WO |
2009082151 | Jul 2009 | WO |
2009088887 | Jul 2009 | WO |
2010036885 | Apr 2010 | WO |
2010089737 | Aug 2010 | WO |
2011043755 | Apr 2011 | WO |
2012064178 | May 2012 | WO |
2013010427 | Jan 2013 | WO |
2013028404 | Feb 2013 | WO |
2013057666 | Apr 2013 | WO |
2014000163 | Jan 2014 | WO |
WO-2014105893 | Jul 2014 | WO |
Entry |
---|
Chiang et al., “Neighborhood-Aware Density Control in Wireless Sensor Networks,” 2008 IEEE International Conferences on Sensor Networks, Ubiquitous, and Trustworthy Computing, 8 pages. |
Balachandran et al., “Adaptive Sleeping and Awakening Protocol (ASAP) for Energy Efficient Adhoc Sensor Networks,” 2005 IEEE, 7 pages. |
Search Report for DE Application 10 2014 012 258.1 dated Mar. 2, 2015 (12 pages). |
Search Report for DE Application 10 2014 012 518.1 dated Feb. 27, 2015 (14 pages). |
Search Report for DE Application 10 2014 012 615.3 dated Jan. 27, 2015 (6 pages). |
Search Report for GB Application 1405790.5 dated Oct. 14, 2014 (5 pages). |
Search Report for GB Application 1403312.0 dated Jun. 25, 2014 (3 pages). |
Search Report for GB Application 1405786.3 dated Jul. 17, 2014 (3 pages). |
Search Report for GB Application 1415178.1 dated Sep. 25, 2014 (5 pages). |
Search Report for GB Application 1405797.0 dated Sep. 2, 2014 (3 pages). |
Search Report for GB Application 1405789.7 dated Sep. 26, 2014 (4 pages). |
Search Report for GB Application 1405797.0 dated Jul. 17, 2014 (4 pages). |
Search Report for GB Application 1415177.3 dated Sep. 10, 2014 (4 pages). |
Search Report for DE Application 10 2014 012 257.3 dated Jan. 27, 2015 (7 pages). |
Search Report for DE Application 10 2014 012 616.1 dated Feb. 3, 2015 (6 pages). |
Search Report for GB Application 1412715.3 dated Jan. 8, 2015 (3 pages). |
Search Report for GB Application 1412722.9 dated Jan. 13, 2015 (6 pages). |
Search Report for GB Application 1501943.3 dated Mar. 20, 2015 ( 4 pages). |
Search report for application No. GB1405789.7 dated Jul. 24, 2014, 4 pages. |
Schutz K: “Trusted Platforms for Homeland Security”, Atmel white paper, Copyright 2004, pp. 1-8, http://www.atmel.com/images/doc5062.pdf. |
Number | Date | Country | |
---|---|---|---|
20150245231 A1 | Aug 2015 | US |