Not Applicable.
Certain embodiments of the invention relate to wireless communication. More specifically, certain embodiments of the invention relate to a method and system for locating Bluetooth® devices. Aspects of the invention are especially adapted for use in a system that provides warnings when a device is no longer in the proximity of a Bluetooth device and for subsequently locating that device in an area, such as a building.
Significant problems may arise when children are brought into public places. Specifically, children often wander away from their parents, become lost or confused, or worse yet, may even be abducted by strangers. Parents have few effective tools for preventing these potential problems or for locating children when such problems arise. Children are often determined to explore but are too young to understand directions to a central meeting point or understand what to do if they are lost. Mechanical restraints are psychologically unappealing. At the same time, operators of malls, amusement parks, and other large venues where children are likely to be guests spend considerable resources in locating lost children. Until they are found, lost children generate considerable anxiety for the parents. There are currently no effective and reasonably priced active electronic devices available that will both alert parents that a child is wandering and allow for an effective, rapid search if a child is lost.
Further limitations and disadvantages of conventional and traditional approaches will become apparent to one of skill in the art, through comparison of such systems with some aspects of the present invention as set forth in the remainder of the present application with reference to the drawings.
Aspects of the invention may be found in a method and system for tracking a Bluetooth® device. The method may comprise the steps of attaching a parent device to a kid device, entering a power saving mode while receiving the signal of the parent device above a specified threshold, entering a search mode when the signal of the parent device falls below a specified threshold, and then returning to a power saving mode when said parent device signal is reacquired. Additional steps may include having the kid device attach to the parent device, issuing an alarm when the received kid signal falls below a threshold, entering a search mode when the signal of the kid device is lost, or returning to a power saving mode when the kid signal is reacquired. Another method of the invention involves tracking a Bluetooth device within a network of Bluetooth devices by providing a network of connected Bluetooth sniffing devices, commanding the sniffing devices to search for a unique hardware identifier associated with a Bluetooth enabled device, and reporting the unique hardware identifier and the hardware identifier of the sniffing device to a central computer when the sniffing device acquires the sniffing signal of the Bluetooth enabled device with the unique hardware identifier. The network may also activate an alarm at the connected sniffing device that has acquired the Bluetooth enabled device.
The system may comprise a plurality of sniffing devices, one or more Bluetooth enabled, wearable devices, each such device having a unique identifier, and a central monitoring system. The central monitoring system is connected to the sniffing devices in a network. The sniffing devices (“kid sniffers”) may include an alarm. The network may be a wireless network. The sniffing devices may be Bluetooth enabled devices. Optionally, the wearable devices (“kid devices”) may be normally dormant in the presence of an associated parent device. The wearable devices may enter an alarm state when said wearable devices detect that the RSSI of an attached device has fallen below a threshold.
Aspects of the invention may be substantially integrated onto a chip, for example a Bluetooth chip, the chip having machine-readable storage having stored thereon a computer program having a code section for the tracking of other Bluetooth devices. The program may include at least one code section being executable by a machine for causing the machine to perform steps comprising those substantially as shown and described with respect to
The integrated circuit of the invention may also include an application layer that performs the methods of the invention. The integrated circuit may also include a signal line activated by a cradle for controlling the application layer when said integrated circuit is resting in a cradle. The integrated circuit is desirably connected to a Bluetooth radio. The application may return to a power saving mode when the measured RSSI exceeds a threshold, or enter a Bluetooth inquiry mode state when said measured RSSI falls below a threshold. The integrated circuit may also have a unique hardware ID.
These and other advantages, aspects and novel features of the present invention, as well as details of an illustrated embodiment thereof, will be more fully understood from the following description and drawings.
Certain embodiments of the invention may be found in a method and system for locating children. More particularly, certain embodiments of the invention may be found in a method and system for locating proximate Bluetooth® devices and warning when a Bluetooth® device leaves the proximity of another Bluetooth® device.
Bluetooth wireless technology is set to revolutionize personal connectivity by providing freedom from wired connections. Bluetooth is a specification for a small form-factor, low-cost radio solution providing links between mobile computers, mobile phones and other portable and handheld devices. Of particular interest is Bluetooth's low power consumption and short range, coupled with the ability of Bluetooth devices to automatically attach to other Bluetooth devices that are close by, typically within 10 meters or less.
About Bluetooth
Bluetooth wireless technology is an international, open standard for allowing intelligent devices to communicate with each other through wireless, short-range communications. This technology allows any sort of electronic equipment—from computers and cell phones to keyboards and headphones—to make its own connections, without wires, cables or any direct action from a user. Bluetooth is currently incorporated into numerous commercial products including laptops, PDAs, cell phones, and printers, with more products coming out every day.
How Bluetooth Works
Bluetooth is a frequency hopping spread spectrum (FHSS) radio system operating in the 2.4 GHz unlicensed band. Its low power transmissions allow a typical range of about 10 meters. Devices connect to each other to form a network known as a piconet, with up to seven active devices in the piconet.
Bluetooth has a protocol stack to transfer data and implement the advanced features required by applications. The protocol stack consists of several different protocols designed for different purposes. The profiles, or applications, reside above the protocol stack. Bluetooth also has a lower protocol stack for link management and baseband control.
Bluetooth hardware implementations are typically highly integrated systems consisting of one or two chips.
The Bluetooth baseband chip consists of a processor core such as an ARM7 with integrated memories 307, Bluetooth baseband 309, and several other peripherals. The radio is implemented in a separate chip 303. The ARM7 processor runs all the required software including a lower stack, an upper stack, and an embedded profile. This type of single CPU implementation allows for a small, low power, low cost solution.
The software “stack” contemplates the insertion of useful applications in the higher layers of the stack. These applications can be designed to take advantage of Bluetooth's lower layers to implement functionality based on Bluetooth radio links.
Three low power modes are specified by Bluetooth, namely, sniff mode, hold mode and park mode. For sniff mode, in normal piconet operation, a device turns on its receiver for its assigned time slot. In sniff mode the device negotiates a regularly spaced interval such that it only needs to turn on its receiver on this interval. A typical sniff interval is 200-1000 milliseconds (ms). The device run may have a SCO (audio) connection open and exchange data over an ACL link. The device will stay in sniff mode until switched back to active mode. Hold mode is similar to sniff mode but on a one-time basis. During hold mode, the device will not receive packets for the hold interval but when the interval ends the device goes back to active mode. The device may have a SCO connection open. In park mode, the device is no longer an active member of the piconet. It periodically listens for beacon packets to maintain synchronization to the piconet. SCO connections are not opened and data is not exchanged on the ACL link. A device will stay in park mode until it is switched back to an active operating mode.
One low power mode is possible on an ACL link between devices. In addition, when switching between modes the device first enters active mode. For example to switch from park to sniff the device switches from park to active to sniff. In accordance with an embodiment of the invention, for low power management, each application sends events to the low power manager. These events may comprise: protocol connection open; protocol connection closed; application open; application closed; SCO open, SCO closed; connection idle; connection busy; and power mode changed to active. Each application has a table indexed by these events. The entry in the table indicates the low power mode preference to take based on that event. There may be more than one low power mode per entry, indicating at least a first preference. For example the first choice may be sniff. If sniff mode fails, the second choice is park. A timer value may also be associated with each mode, such that the low power mode switch will take place after the timer expires.
In an exemplary embodiment, the system utilizes at least two devices, a parent device and a kid device. The parent device can be any BT enabled device, such as, for example, a cell phone with Bluetooth. The kid device is again, any BT device, such as, for example, a high volume, low cost, specialized device optimized for low power consumption. The kid device is designed to be wearable, and can take the form of a wrist watch, ankle bracelet, key fob, or any other convenient shape. The kid device includes a rechargeable battery with sufficient power for approximately 24 hours of operation. When not in use, the device is stored in a cradle that keeps the kid device fully charged.
The system is initialized by “attaching” the kid and parent devices. Attachment is accomplished using the BT protocol for this purpose. Attachment is performed between the two devices at any convenient time, and can be triggered for example by menu selection on the parent cell phone 501 and a button press 409 on the kid device. The processes discussed below are described in detail by the Bluetooth protocol, most recently document Core Specification v2.0+EDR Volume 3 Core System Package [Host volume] Part C: Generic Access Profile Section 7: Establishment Procedures.
Reference to
For the parent device, the initial state is an idle state 601. Based on a menu selection, the parent device can transition to an initial setup state 603. In initial setup state 603, the parent device starts an inquiry process to find possible kid devices. The user interface may offer a list of candidate devices, and the user selects from the list. The kid device is then paged. If the page succeeds, the parent device transitions to the connected state 605. In the connected state 605, the kid device and the parent device negotiate on a sleep time for the hold mode. When the parent device wakes up, it reads RSSI. The parent device also sends a message to all the connected kid devices and remains awake to receive a response. If the message is not answered within a set time, for example 10 seconds, the parent device will again transition to the alarm state 607. If any of the connected kid devices have a read RSSI that is below a set threshold, the parent device transitions to the alarm state 607. Once in the alarm state, the user is alerted with the name and address of the lost kid device. Once the kid device is reacquired, the parent device transitions back to the connected state 605, unless the user chooses to disengage the parent device in which case the parent device transitions to the idle state 601. Note that if the kid device has already been paired with the parent device, the parent device can transition directly from the idle state 601 through the connection process 609 to the connected state 605.
The states for the kid device are similar to those for the parent device. Initially, it is assumed that the kid device is off in state 600. Power is activated by a button press. The press may be longer if it is desired to enter the initial setup state 602. In the setup state 602, the kid device is discoverable and connectable. When a parent device connects, the kid device can then transition to the connected state 604. In the connected state, the kid device is set such that it is in a non-discoverable and non-connectable mode. The kid device will only talk to the connected parent device. The kid device and the parent device agree on a sleep time and enter hold mode. When the kid device wakes up, it will stay awake until it receives a message from the parent device. If the message is not received within a minimum time, for example 10 seconds, the kid device will enter the lost state 606.
In the lost state 606, the device is discoverable and connectable. The kid device will allow itself to be discovered by, and connected to, any device that is performing inquiries or that is paging the device. Lost state can only be exited by either complete loss of power, resulting in the total reset of the kid device, or connecting with the original parent device and returning to the connected state 604. Timers can be advantageously employed in the lost state 606 to extend the life of the kid device battery in the event that connection is not quickly established with the parent device. Optionally, the kid device could be allowed to transition from the lost state 606 by a button press on the kid device, however as a security feature it is contemplated that it may be preferable to only allow power on/off and setup for the kid device in the presence of the paired parent device.
It will be noted that as a security feature, the kid device 401 can therefore only be logically detached when it is in proximity to the device that it is currently attached to. Furthermore, the kid device is always “on” in the sense that it is only deactivated when it senses that it is both in proximity to its attached device or in a cradle. In this respect, the kid device can be made not to turn off when in the lost state 606 except by physical destruction or the exhaustion of its power supply.
Once attached, the parent device interrogates the lower stack 215 for the value of RSSI. BT devices track RSSI, and this value is available to application layer software. The application layer in the parent device 501 queries for an updated RSSI value at intervals that correspond to the hold mode sleep timer. The interval can be adjusted for security and power drain. It is contemplated that an update interval of approximately once every three seconds should be sufficient to provide reasonable warning and conserve power.
The kid device may be programmed to change states only when parent contact is lost for a minimum number of cycles. It is contemplated that this period would be approximately ten seconds, although longer or shorter periods could be selected based on commercial experience. The parent device RSSI threshold is preferred to be variable, allowing the parent to select through keypad 503 “longer” or “shorter” distances at which the parent device will change state based on the needs of the parent, up to the maximum Bluetooth range of about 10 meters. Note that at extremely low thresholds, an unusually favorable radio environment could keep the parent device from alarming at longer distances than desired, so it is contemplated that the RSSI threshold would be set above zero.
The kid device may be programmed to adopt a variable duty cycle for active radio transmission, wherein the device actively transmits more frequently in the initial period of being “lost” and less frequently after a period of time in order to conserve power while continuing to broadcast. Upon initially losing the parent device signal, the kid device may also audibly alarm speaker 413 with ring tones and/or vibrate. In the same way, the ring tones may be repeated at decreasing intervals depending on the battery capacity of the kid device.
The parent device will not change BT states unless acquisition is actually lost. Assuming that the RSSI threshold is sufficiently high, the parent device may generate an audible ring 1 warning from speaker 509 to the user to warn that the RSSI limit has been exceeded before contact has been lost. This ring provides a first level of warning that a child is wandering off and can be issued while the parent device is still in a connected state 605. If contact is actually lost and the device has transitioned to alarm state 607, then the parent device will begin paging the kid device and generate an audible ring 2 warning. The parent device may also display a message in the display area 507 of the parent device stating the time signal was lost and reciting the unique hardware device identifier number of the kid device that was lost.
When the parent device reacquires the kid device and returns to the connected state 605, an audible ring 3 may be generated by the parent device as well as a text message, and the parent device will transition to “hold” mode. When the RSSI threshold is met, the parent device will generate an audible ring 4 and display the message “kid # reacquired” in the message area. Ring or other tones 1-4 are optional and may be of any suitable tone to convey a message of alarm or reassurance, and are readily implemented on standard cell phone chipsets that allow for customized rings based on the source of the message. Other combinations of tones and/or vibration (from vibrating accessory 505) and text messages may be implemented based on design preference and the availability of call signaling features in the underlying parent Bluetooth enabled device.
The logical functions of the sniffer are limited and sufficient space exists in the chipsets provided by Broadcom for Bluetooth and 802.x implementations that the overall complexity and cost of the sniffer hardware is kept to a minimum.
Operation of the sniffer network is described in reference to
The central monitoring point includes a standard computer 805 equipped as a node on the network that manages the sniffer devices. If a parent device alarms and the parent or guardian notifies the administrative authority such as mall security, campus police, or camp administration, the unique device identifier of the kid device can be entered into the central system. The central system broadcasts a global command to all sniffer devices on its network to cycle from a dormant Bluetooth state to an active state where every kid sniffer device in the network performs inquiry scans and pages for the kid device. Each sniffer that “finds” the kid device reports back the RSSI and its own hardware identifier to the central computer.
It is contemplated that the central application will contain a current mapping of sniffer unique device Ids to physical locations. Note that because Bluetooth allows a single device to inquire for an unlimited number of physical associated devices, the central site can “seek” for as many lost devices at once as network capacity and memory will allow. Alternatively, the site can be preprogrammed with Ids of devices that it is desired to track continuously. Note also that it is not necessary to have a parent device 507 involved in this system at all: The central computer 805 is capable of tracking any Bluetooth device with the kid tracker application enabled whose unique device ID is known to the administrator. Once the last reported sniffer location is displayed, the information can be relayed to appropriate field personnel, either by voice radio or by automatic message generation over a wireless messaging system such as SMS or regular e-mail to designated PDAs.
It is also contemplated that any Bluetooth devices, that have access from the Internet 809 through gateway device 811 to network backbone 711, may be enrolled in the sniffer network. This allows roaming devices to participate in a search as well. The number of roaming devices is limited only by the ability of the network to enroll additional devices through the gateway 811 and communicate information about the unique ID of the kid device that is being sought, and the willingness of the holders of Bluetooth devices connected to those networks to participate in the search described. Eligible devices and networks would be pre-registered in a broadcast list of willing “Amber Alert” devices and networks that include BT enabled devices, maintained on central computer 805. When initiated by the system, roaming devices connected to the network 801 through the internet can thus enlisted to participate in an “Amber Alert” that involves hundreds or even thousands of BT enabled devices in a very large area search for a missing kid device. Any roaming device that successfully pages for the kid device then sends an e-mail message to the system operator with contact information. The central system may also be programmed with an automated reply that includes instructions on what to do next. The entire process can be automated to the point that once a Bluetooth device is enrolled in the program, the owner of the device does not need to take any action to participate in the search network, other than respond to any automated e-mails seeking location information in the event a kid device is found by the owners Bluetooth device.
A powerful, flexible system for providing short range tracking of wandering persons (or anything else that is mobile and needs watching) that can be built into the functionality resident in Bluetooth enabled devices. The kid application is sufficiently portable to other devices, for example, that the functions of
Aspects of the present invention may be realized in hardware, software, or a combination of hardware and software. The present invention may be realized in a centralized fashion in at least one computer system, or in a distributed fashion where different elements are spread across several interconnected computer systems. Any kind of computer system or other apparatus adapted for carrying out the methods described herein is suited. A typical combination of hardware and software may be a general-purpose computer system with a computer program that, when being loaded and executed, controls the computer system such that it carries out the methods described herein.
The present invention may also be embedded in a computer program product, which comprises all the features enabling the implementation of the methods described herein, and which when loaded in a computer system is able to carry out these methods. Computer program in the present context means any expression, in any language, code or notation, of a set of instructions intended to cause a system having an information processing capability to perform a particular function either directly or after either or both of the following: a) conversion to another language, code or notation; b) reproduction in a different material form.
While the present invention has been described with reference to certain embodiments, it will be understood by those skilled in the art that various changes may be made and equivalents may be substituted without departing from the scope of the present invention. In addition, many modifications may be made to adapt a particular situation or material to the teachings of the present invention without departing from its scope. Therefore, it is intended that the present invention not be limited to the particular embodiment disclosed, but that the present invention will include all embodiments falling within the scope of the appended claims.