WO2013056145A1 - Power-aware tiered geofencing and beacon watchlists - Google Patents
Power-aware tiered geofencing and beacon watchlists Download PDFInfo
- Publication number
- WO2013056145A1 WO2013056145A1 PCT/US2012/060091 US2012060091W WO2013056145A1 WO 2013056145 A1 WO2013056145 A1 WO 2013056145A1 US 2012060091 W US2012060091 W US 2012060091W WO 2013056145 A1 WO2013056145 A1 WO 2013056145A1
- Authority
- WO
- WIPO (PCT)
- Prior art keywords
- processor
- computing device
- beacons
- geofence
- positioning
- Prior art date
Links
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04W—WIRELESS COMMUNICATION NETWORKS
- H04W4/00—Services specially adapted for wireless communication networks; Facilities therefor
- H04W4/02—Services making use of location information
- H04W4/021—Services related to particular areas, e.g. point of interest [POI] services, venue services or geofences
-
- G—PHYSICS
- G01—MEASURING; TESTING
- G01S—RADIO DIRECTION-FINDING; RADIO NAVIGATION; DETERMINING DISTANCE OR VELOCITY BY USE OF RADIO WAVES; LOCATING OR PRESENCE-DETECTING BY USE OF THE REFLECTION OR RERADIATION OF RADIO WAVES; ANALOGOUS ARRANGEMENTS USING OTHER WAVES
- G01S19/00—Satellite radio beacon positioning systems; Determining position, velocity or attitude using signals transmitted by such systems
- G01S19/01—Satellite radio beacon positioning systems transmitting time-stamped messages, e.g. GPS [Global Positioning System], GLONASS [Global Orbiting Navigation Satellite System] or GALILEO
- G01S19/13—Receivers
- G01S19/34—Power consumption
-
- G—PHYSICS
- G01—MEASURING; TESTING
- G01S—RADIO DIRECTION-FINDING; RADIO NAVIGATION; DETERMINING DISTANCE OR VELOCITY BY USE OF RADIO WAVES; LOCATING OR PRESENCE-DETECTING BY USE OF THE REFLECTION OR RERADIATION OF RADIO WAVES; ANALOGOUS ARRANGEMENTS USING OTHER WAVES
- G01S5/00—Position-fixing by co-ordinating two or more direction or position line determinations; Position-fixing by co-ordinating two or more distance determinations
- G01S5/01—Determining conditions which influence positioning, e.g. radio environment, state of motion or energy consumption
-
- G—PHYSICS
- G01—MEASURING; TESTING
- G01S—RADIO DIRECTION-FINDING; RADIO NAVIGATION; DETERMINING DISTANCE OR VELOCITY BY USE OF RADIO WAVES; LOCATING OR PRESENCE-DETECTING BY USE OF THE REFLECTION OR RERADIATION OF RADIO WAVES; ANALOGOUS ARRANGEMENTS USING OTHER WAVES
- G01S5/00—Position-fixing by co-ordinating two or more direction or position line determinations; Position-fixing by co-ordinating two or more distance determinations
- G01S5/01—Determining conditions which influence positioning, e.g. radio environment, state of motion or energy consumption
- G01S5/019—Energy consumption
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/50—Network services
- H04L67/52—Network services specially adapted for the location of the user terminal
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04W—WIRELESS COMMUNICATION NETWORKS
- H04W64/00—Locating users or terminals or network equipment for network management purposes, e.g. mobility management
-
- G—PHYSICS
- G01—MEASURING; TESTING
- G01S—RADIO DIRECTION-FINDING; RADIO NAVIGATION; DETERMINING DISTANCE OR VELOCITY BY USE OF RADIO WAVES; LOCATING OR PRESENCE-DETECTING BY USE OF THE REFLECTION OR RERADIATION OF RADIO WAVES; ANALOGOUS ARRANGEMENTS USING OTHER WAVES
- G01S19/00—Satellite radio beacon positioning systems; Determining position, velocity or attitude using signals transmitted by such systems
- G01S19/38—Determining a navigation solution using signals transmitted by a satellite radio beacon positioning system
- G01S19/39—Determining a navigation solution using signals transmitted by a satellite radio beacon positioning system the satellite radio beacon positioning system transmitting time-stamped messages, e.g. GPS [Global Positioning System], GLONASS [Global Orbiting Navigation Satellite System] or GALILEO
- G01S19/42—Determining position
- G01S19/48—Determining position by combining or switching between position solutions derived from the satellite radio beacon positioning system and position solutions derived from a further system
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04W—WIRELESS COMMUNICATION NETWORKS
- H04W52/00—Power management, e.g. TPC [Transmission Power Control], power saving or power classes
- H04W52/02—Power saving arrangements
- H04W52/0209—Power saving arrangements in terminal devices
- H04W52/0261—Power saving arrangements in terminal devices managing power supply demand, e.g. depending on battery level
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04W—WIRELESS COMMUNICATION NETWORKS
- H04W52/00—Power management, e.g. TPC [Transmission Power Control], power saving or power classes
- H04W52/02—Power saving arrangements
- H04W52/0209—Power saving arrangements in terminal devices
- H04W52/0261—Power saving arrangements in terminal devices managing power supply demand, e.g. depending on battery level
- H04W52/0287—Power saving arrangements in terminal devices managing power supply demand, e.g. depending on battery level changing the clock frequency of a controller in the equipment
- H04W52/0293—Power saving arrangements in terminal devices managing power supply demand, e.g. depending on battery level changing the clock frequency of a controller in the equipment having a sub-controller with a low clock frequency switching on and off a main controller with a high clock frequency
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02D—CLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
- Y02D30/00—Reducing energy consumption in communication networks
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02D—CLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
- Y02D30/00—Reducing energy consumption in communication networks
- Y02D30/70—Reducing energy consumption in communication networks in wireless communication networks
Definitions
- Geofencing may be implemented in existing systems in several ways, one of which relies on location polling.
- a mobile telephone continually polls for its location and that location is compared to the location of an area of interest to determine whether the mobile telephone is within the area of interest.
- Example areas of interest may include a home, workplace, or a nearby friend.
- the existing systems are battery intensive thus degrading the user experience. For example, many applications request near real-time updates of the location of the mobile telephone even when the mobile telephone is far away from the areas of interest.
- Embodiments of the disclosure provide power-aware tiered geofencing.
- a computing device identifies a set of beacons associated with a geofence.
- the computing device has at least a first processor and a second processor, wherein the first processor consumes less power when operating than the second processor.
- the first processor is provided with the identified set of beacons.
- the second processor is disabled while the first processor detects one or more beacons proximate to the computing device using a first one of a plurality of positioning modalities.
- the first processor further compares the detected beacons with the provided set of beacons to determine whether the computing device is within or nearby the geofence. Based on the comparison, a second one of the plurality of positioning modalities is selected.
- the second processor is enabled based on the selected second one of the plurality of positioning modalities.
- the computing device implements the selected second one of the plurality of positioning modalities to detect additional beacons.
- FIG. 1 is an exemplary block diagram illustrating a mobile computing device entering and exiting a geofence around a house.
- FIG. 2 is an exemplary block diagram illustrating operation of the computing device to detect beacons and select a positioning modality.
- FIG. 3 is an exemplary flow chart illustrating operation of the computing device to select a positioning modality based on a determined distance from a geofence.
- FIG. 4 is an exemplary flow chart illustrating operation of the computing device to implement beacon watch lists.
- FIG. 5 is an exemplary block diagram illustrating beacon coverage around a geofence.
- FIG. 6 is an exemplary block diagram illustrating cell tower coverage overlapping other beacon coverage near a geofence.
- FIG. 7 is an exemplary chart illustrating coverage of various positioning modalities.
- embodiments of the disclosure support power- aware geofencing applications in multi-processor devices. Some embodiments enable real-time or near real-time notifications whenever a computing device 202 enters and/or exits a virtual perimeter defined by a geofence. Further, with tiered geofencing, the computing device 202 (e.g., a mobile computing device 104) saves power by switching among different methods of location determination (e.g., via different positioning modalities) having different levels of power consumption. For example, implementing Wi-Fi or satellite-based positioning consumes more power than implementing cellular- based positioning. The switching is dependent on a current location of the computing device 202, a distance from the computing device 202 to the geofence(s), an error range or accuracy of the positioning modality and/or beacon, the size of the geofences, and/or other factors.
- the geofencing applications may be implemented with or without location determination (e.g., using positioning modalities that may either determine location or detect proximity to beacons 204).
- aspects of the disclosure disable the high power processor(s) and rely on the low power processor(s) to monitor the location of the computing device 202.
- aspects of the disclosure implement higher accuracy methods of monitoring.
- the computing device 202 is once again far away from the geofence, the greater power-consuming positioning modalities are disabled again. In this manner, low power and low accuracy positioning modalities are used to determine whether to switch to higher power and higher accuracy positioning modalities, thus reducing power consumption by the computing device 202.
- aspects of the disclosure compare detected proximate beacons 204 to a set of beacons associated with the geofence. In this manner, the entry or exit of the computing device 202 relative to the geofence can be determined by a lower power positioning modality without calculating the actual location of the computing device 202. This allows the higher-power-consumption positioning modalities to remain disabled until a geofence entry event or geofence exit event is triggered, or the device is known to be nearby the geofence. Power is thus conserved over existing methods.
- a user 206 of the computing device 202 is also able to associate location status privacy settings with the geofence or other beacons 204 (e.g., for sharing location status with other users).
- an exemplary block diagram illustrates the mobile computing device 104 entering and exiting a geofence 102 around a house.
- the geofence 102 represents a virtual perimeter of a geographic area of interest. While the geofence 102 illustrated in FIG. 2 and elsewhere is represented by a circle, aspects of the disclosure are operable with any size or shape of geofence 102. Aspects of the disclosure are further operable with geofences in both two- and three-dimensions. For example, a geofence may be established around one or more floors of an office building.
- While some aspects of the disclosure disclose the mobile computing device 104 performing operations such as shown in FIG. 3 and FIG. 4, the disclosure is operable with any computing device capable of entering and exiting the geofence. Such an exemplary computing device is described next with reference to FIG. 2.
- an exemplary block diagram illustrates operation of the computing device 202 to detect beacons 204 and select a positioning modality.
- the computing device 202 e.g., a mobile telephone detects or observes one or more of the beacons 204 including cellular towers (or sectors if directional antennas are employed) such as for cellular division multiple access (CDMA), wireless fidelity (Wi-Fi) access points, satellites, or other wireless access points (WAPs) such as for the Global System for Mobile Communication (GSM) and 4G/Wi-Max via one or more location sensors 213 of the computing device 202.
- CDMA cellular division multiple access
- Wi-Fi wireless fidelity
- satellites satellites
- WAPs wireless access points
- GSM Global System for Mobile Communication
- 4G/Wi-Max wireless access points
- exemplary beacons 204 include cellular towers, base stations, base transceiver stations, base station sites, and/or any other network elements supporting any quantity and type of communication modes. While some embodiments of the disclosure may be described with reference to the beacons 204 implementing protocols such as the 802.11 family of protocols, embodiments of the disclosure are operable with any beacon 204.
- beacons 204 may include ultrasonic beacons.
- the computing device 202 communicates with a location service 208 via a network 210 to determine the location of the computing device 202.
- the location service 208 is part of or otherwise associated with the computing device 202.
- the computing device 202 is able to determine the location of the computing device 202 without external communication with the location service 208.
- the location service 208 implements location determination algorithms based on input from the computing device 202.
- the location service 208 may implement satellite-based positioning, cellular-based positioning, Wi-Fi-based positioning, BLUETOOTH-based positioning, and the like, based on input received from the computing device 202.
- beacon-based location determination a list of nearby beacons 204 (e.g., Wi-Fi beacons or cell towers) is collected.
- the location of each of the beacons 204 can be looked up using a unique identifier such as an address of each beacon 204.
- the position of the computing device 202 can be estimated based on the proximity to each of the beacons 204 in the set and the known locations of the beacons 204.
- the computing device 202 associated with the user 206 represents a system for power-aware tiered geofencing.
- the computing device 202 represents any device executing instructions (e.g., as application programs, operating system functionality, or both) to implement the operations and functionality associated with the computing device 202.
- the computing device 202 may include the mobile computing device 104 or any other portable device.
- the mobile computing device 104 includes a mobile telephone, laptop, tablet, computing pad, netbook, gaming device, and/or portable media player.
- the computing device 202 may also include less portable devices such as desktop personal computers, kiosks, and tabletop devices. Additionally, the computing device 202 may represent a group of processing units or other computing devices. As described above with reference to FIG. 1, the computing device 202 represents any device capable of entering and exiting the geofence.
- the computing device 202 includes a single processor. In other embodiments, the computing device 202 has at least two processors, one or more sensors, and a memory area 216.
- the processors include a first processor 212 and a second processor 214, where the first processor 212 consumes less power when operating than the second processor 214.
- the first processor 212 may be a modem processor while the second processor 214 is a primary processor.
- the first processor 212 may be a processor designed to consume less power than the second processor 214.
- the first processor 212 may be a processor similar to the second processor 214 except that the first processor 212 has transitioned to a low power state by, for example, disabling selected hardware functionality (e.g., caches), reducing the clock speed, or any other known method for reducing power consumption.
- selected hardware functionality e.g., caches
- An exemplary computing device 202 may have a plurality of processors including a primary processor, a graphics processing unit, a Wi-Fi chipset, a
- BLUETOOTH chipset a cellular modem or radio, and others. Some of the processors consume more power than others, and there may be a power consumption cost incurred when one of the processors switches from a low power state to a higher power state (or vice versa).
- the processors include any quantity of processing units, and are programmed to execute computer-executable instructions for implementing aspects of the disclosure.
- the instructions may be performed by the processors or by multiple processors executing within the computing device 202, or performed by one or more processors external to the computing device 202.
- the processors are programmed to execute instructions such as those illustrated in the figures (e.g., FIG. 3 and FIG. 4).
- the computing device 202 also has one or more location sensors 213 associated therewith.
- the location sensors 213 may be internal and/or external to the computing device 202.
- Exemplary location sensors 213 include, but are not limited to, a cellular radio or modem, a GPS receiver, a Wi-Fi adapter or modem, a BLUETOOTH brand communication service element, a three-dimensional motion sensor, or the like.
- the computing device 202 further has one or more computer readable media such as the memory area 216.
- the memory area 216 includes any quantity of media associated with or accessible by the computing device 202.
- the memory area 216 may be internal to the computing device 202 (as shown in FIG. 2), external to the computing device 202 (not shown), or both (not shown).
- the memory area 216 stores, among other data, one or more applications 218.
- Exemplary applications 218 include mail application programs, web browsers, calendar application programs, address book application programs, messaging programs, media applications, location-based services, search programs, and the like.
- the applications 218 may communicate with counterpart applications or services such as web services accessible via the network 210.
- the applications 218 may represent downloaded client-side applications that correspond to server-side services executing in a cloud.
- one or more of the applications 218 rely on information describing a location of the computing device 202.
- the location may represent a status (e.g., inside and/or outside the geofence) or an actual determination location (e.g., coordinates).
- the applications may perform particular actions based on the determined location of the computing device 202 relative to the geofence. Examples of the execution of such applications are described below.
- the memory area 216 further stores accuracy thresholds corresponding to the positioning modalities and/or the beacons.
- the accuracy thresholds are defined based on implementation of the various positioning modalities (e.g., an error range or accuracy value) and, in some embodiments, the size of the geofence.
- the positioning modalities correspond to the location sensors 213.
- the positioning modalities include cellular-based positioning, satellite-based positioning, Wi- Fi-based positioning, and BLUETOOTH -based positioning.
- Each of the positioning modalities has one of the accuracy thresholds 222 associated therewith.
- the accuracy threshold 222 represents a range or accuracy of the positioning modality. In other embodiments, the accuracy threshold 222 represents a range or accuracy of a particular beacon or beacon type.
- Exemplary accuracy thresholds 222 include approximately two kilometers for cellular- based location determination, approximately 250 meters for Wi-Fi-based location determination, and approximately five meters for satellite-based location determination.
- the accuracy threshold 222 may be defined based on empirical data from the computing device 202 or other computing devices (e.g., based on a success rate of previous applications or implementations of the positioning modality).
- the memory area 216 further stores one or more computer-executable components.
- Exemplary components include a geofence component 224, a sensor component 226, a boundary component 228, a location component 230, and a privacy component 232. Operation of the components, when executed, is described below with reference to FIG. 4.
- an exemplary flow chart illustrates operation of the computing device 202 to select a positioning modality based on a determined distance from the geofence 102.
- distance from the geofence 102 is not explicitly determined, but whether the computing device 202 is within, nearby and potentially inside, or not inside the geofence 102.
- the computing device 202 identifies a set of beacons associated with the geofence 102 or other area of interest. For example, the computing device 202 may identify one or more beacons 204 having a radius that overlaps with or is contained within a geographic area associated with the geofence 102.
- the computing device 202 queries the location service 208 or another entity (e.g., a cloud service) to obtain the set of beacons and store the set of beacons on the computing device 202.
- the location service 208 maintains a beacon database (e.g., or in a file or in memory) that includes the approximate location and range of each beacon 204. Based on the location of the geofence(s) of interest, the location service 208 can query or filter the beacon database to identify the beacons 204 that intersect or are contained within the geofence 102.
- the computing device 202 may access the memory area 216 to build the set of beacons.
- the set of beacons may include beacons 204 of any type (e.g., cellular, Wi-Fi, etc.) and of any combination of types.
- the identified set of beacons represents possible areas of interest to the user 206, and may include a plurality of geofences 102.
- the set of beacons may also be referred to as a beacon watch list.
- the set of beacons is provided to the first processor 212 or another low power processor.
- the first processor 212 may be provided a pointer or register value indicating where the set of beacons is available for access.
- the second processor 214, or any other processor consuming more power than the first processor 212 is disabled to reduce power consumption.
- Disabling the second processor 214 includes, for example, de-energizing the second processor 214, setting the second processor 214 to a low power mode, or otherwise adjusting the second processor 214 to consume less power. In this manner, the second processor 214 may be disabled indefinitely until enabled as described below.
- the first processor 212 determines a distance from the computing device 202 to the geofence 102 at 308. For example, the first processor 212 obtains a location of the computing device 202 using one of the positioning modalities capable of implementation by the first processor 212. The first processor 212 compares the location of the computing device 202 with the locations and/coverage of the beacons 204 in the set of beacons defining the geofence 102 to calculate the distance from the computing device 202 to the geofence 102. The computing device 202 may be moving towards the geofence 102, moving away from the geofence 102, or stationary.
- the first processor 212 compares the determined distance with the accuracy thresholds 222 associated with each of the positioning modalities, or associated with the particular location determination fix (e.g., from 308). At 312, based on the comparison, the first processor 212 selects one of the positioning modalities. In some embodiments, the first processor 212 selects one or more of the positioning modalities having accuracy thresholds 222 that are greater than the determined distance. For example, if the determined distance is greater than the accuracy threshold 222 using a first one of the positioning modalities but less than the accuracy threshold 222 using a second one of the positioning modalities, then the first processor 212 selects the first positioning modality.
- the first processor 212 may switch to a positioning modality with a smaller accuracy threshold 222 (e.g., higher accuracy).
- the first processor 212 identifies the processor(s) needed for
- the second processor 214 is not enabled. Otherwise, if the first processor 212 determines that the second processor 214 should be enabled at 314, the second processor 214 is enabled at 316. For example, the first processor 212 may send a notification to the second processor 214 to enable the second processor 214. While discussed in the context of the first processor 212 and the second processor 214, aspects of the disclosure are operable with any quantity of processors.
- the location of the computing device 202 is determined using the selected positioning modality. For example, at least the second processor 214 proceeds to perform operations 308, 310, 312, 314, and 316 (in some cases).
- the computing device 202 calculates or receives a success rate associated with use of the selected positioning modality.
- the success rate may be represented as a value indicating whether a location could be determined, a radius of error associated with the determined location, speed of the fix, or another metric.
- the computing device 202 analyzes the success rate and may adjust any of the accuracy thresholds 222 to be greater or less depending on the success rate.
- an exemplary flow chart illustrates operation of the computing device 202 to implement beacon watch lists.
- the operations illustrated in FIG. 4 are performed using a beacon watch list and without determining a location of the computing device 202.
- the beacon watch list enables a geofencing implementation with reduced power consumption by the computing device 202 due to the lack of location polling.
- the computing device 202 identifies a set of beacons associated with the geofence 102.
- the computing device 202 may query the location service 208 or another entity to obtain the set of beacons.
- the set of beacons is provided to the first processor 212 or another low power processor.
- the second processor 214, or any other processor consuming more power than the first processor 212 is disabled to reduce power consumption.
- the first processor After receiving or being notified of the set of beacons, the first processor
- the 212 detects one or more beacons 204 proximate to the computing device 202 at 408 using a first positioning modality (e.g., cellular-based).
- the first processor 212 compares the detected beacons 204 with the set of beacons associated with the geofence 102 at 410 to determine if the computing device 202 is within or nearby the geofence 102. For example, the first processor 212 determines if one of the detected beacons 204 is also part of the set of beacons. If one of the detected beacons 204 is also in the set of beacons, the first processor 212 determines whether the range or coverage area of that beacon 204 is entirely within the geofence 102.
- a first positioning modality e.g., cellular-based
- the first processor 212 concludes that the computing device 202 is within the geofence 102.
- the first processor 212 may instead determine that the range of the beacon 204 is partly within the geofence 102 and that the range is within a margin of error. If so, the first processor 212 concludes that the computing device 202 is within the geofence 102.
- the first processor 212 may instead determine that the range of the beacon 204 is partly within the geofence 102 and that the range is greater than the margin of error.
- the first processor 212 concludes that a different beacon type with greater accuracy (e.g., Wi-Fi instead of cellular) should be detected to determine whether the computing device 202 is within the geofence 102 (e.g., see operations 314, 316, and 318 in FIG. 3).
- a different beacon type with greater accuracy e.g., Wi-Fi instead of cellular
- the first processor 212 determines that the computing device 202 is not within or nearby the geofence 102 at 412, the first processor 212 subsequently re-performs operations 408, 410, and 412 using the same positioning modality (e.g., the first positioning modality). For example, the first processor 212 may detect other beacons 204 after a predefined time period elapses (e.g., every ten seconds, every five minutes, every hour, etc.). In another example, the first processor 212 may reduce the frequency of re- performing the operations (e.g., by a back-off factor or amount). In some embodiments, the frequency reduction is tied to a determination or signal that the user 206 is stationary (e.g., based on detecting the same set of beacons more than once, or based on
- the first processor 212 determines that the computing device 202 is within or nearby the geofence 102 at 412, the first processor 212 selects a second positioning modality (e.g., Wi-Fi-based) at 414. If the second processor 214 is needed for implementation of the selected second positioning modality, the second processor 214 is enabled at 416. Enabling the second processor 214 includes, but is not limited to, energizing the second processor 214, setting or configuring the second processor 214 to a higher power or full power mode, adjusting the second processor 214 to consume more power, waking the second processor 214, or interrupting the second processor 214.
- a second positioning modality e.g., Wi-Fi-based
- the computing device 202 detects additional beacons (e.g., of the type corresponding to the second positioning modality) at 418 to enable location determination with greater accuracy.
- additional beacons e.g., of the type corresponding to the second positioning modality
- the computing device 202 may perform any operation associated with entry into, or exit from, the geofence 102. For example, the computing device 202 may update a location status based on whether or not the computing device 202 is within the geofence 102. In some embodiments, the computing device 202 updates the location status after determining whether the computing device 202 is within or nearby the geofence 102 at 412, and without performing operations 414, 416, or 418.
- the computing device 202 may create a tag for association with content (e.g., photos) created or captured by the computing device 202 while within the geofence 102.
- the tag provides context information based on the updated location status.
- the tag may be created from user data stored on the computing device 202 (e.g., from data provided by the user 206 describing the geofence 102), or may be created from data obtained from another source such as the Internet.
- the computer-executable components illustrated in FIG. 2 are executed by the first processor 212 or the second processor 214 to perform the operation illustrated in FIG. 4.
- the geofence component 224 when executed by the first processor 212, causes the first processor 212 to identify the set of beacons associated with the geofence 102.
- the geofence component 224, the sensor component 226, and the boundary component 228 execute while the second processor 214 is disabled.
- the location component 230 when executed by the first processor 212, causes the first processor 212 to enable the second processor 214 based on whether the computing device is within or nearby the geofence 102 as determined by the boundary component 228.
- at least the second processor 214 executes to detect additional beacons to update a location status of the computing device 202.
- the privacy component 232 when executed by the computing device 202, enables the user 206 to set privacy settings.
- the privacy settings may be based on the location status (e.g., whether or not the computing device 202 is within the geofence 102).
- the user 206 may specify that information describing whether or not the computing device 202 is within one of the geofences 102 may be shared, but that real-time tracking information for the computing device 202 may not be shared.
- FIG. 5 an exemplary block diagram illustrates beacon coverage around a geofence. In the example of FIG. 5, the circle indicated by the solid line represents the geofence.
- the other circles represent the range and position of beacons 204 that intersect or are contained within the geofence.
- the circles with the horizontal Crosshatch pattern represent beacons 204 whose coverage overlaps with the geofence (e.g., part of the coverage is within the geofence, while the rest of the coverage is outside the geofence).
- the computing device 202 encounters these beacons 204 first as the computing device 202 approaches the geofence, and these beacons 204 last as the computing device 202 exits the geofence.
- the circles with the vertical Crosshatch pattern represent beacons 204 whose coverage is contained entirely within the geofence.
- the beacons 204 may be Wi-Fi beacons.
- beacon coverage is represented by circles in FIG. 5 and elsewhere in the disclosure, actual beacon coverage differs among the beacons 204 and may take any form or shape.
- an exemplary block diagram illustrates cell tower coverage overlapping other beacon coverage near a geofence.
- the small circles represent Wi-Fi beacons while the large circles (e.g., circle 602) represent cell towers with a broader coverage area (e.g., error radius) than the Wi-Fi beacons.
- the four cell towers and the Wi-Fi beacons are included in a beacon watch list stored by the computing device 202.
- the computing device 202 applies a cell-based positioning modality to detect proximate cell towers (e.g., a Wi-Fi modem is powered off to save power). If the computing device 202 is connected to a cell tower other than one of the four cell towers on the beacon watch list, the computing device 202 concludes that it is not near the geofence and that the Wi-Fi modem should remain powered off.
- the computing device 202 If the computing device 202 is connected to one of the four cell towers on the beacon watch list, the computing device 202 concludes that it may be near or within the geofence, but that a positioning modality with a higher accuracy (e.g., a smaller accuracy threshold 222, or a smaller margin of error) for location determination should be employed. As such, the computing device 202 then powers on the Wi-Fi modem to detect proximate Wi-Fi beacons (e.g., in addition to detecting proximate cell towers). Once the computing device 202 is no longer connected to one of the four cell towers, the computing device 202 powers off the Wi-Fi modem to conserve power and only uses the cellular radio to detect proximate beacons 204.
- a positioning modality with a higher accuracy e.g., a smaller accuracy threshold 222, or a smaller margin of error
- FIG. 7 an exemplary chart illustrates coverage of various positioning modalities. Aspects of the disclosure are operable to switch among any known or future positioning modality.
- the exemplary modalities illustrated in FIG. 7 include satellite communication systems (e.g., GPS and assisted GPS), Wi-Fi
- IP Internet protocol
- the accuracy of the positioning modality decreases as the distance increases along the horizontal axis of the chart.
- the computing device 202 conserves power while providing real-time location tracking.
- the geofencing implementation described in the disclosure conserves power by disabling realtime tracking hardware (e.g., GPS) upon entry to a geofence and enabling the real-time tracking hardware upon leaving the geofence.
- aspects of the disclosure enable the user 206 to automatically "check- in” and automatically “check-out” from a venue (e.g., a coffee shop, store, restaurant, etc.) using the geofencing implementations described herein.
- a geofence is defined for each venue.
- the user 206 is presented with an option to allow automatic check- in and/or check-out from each particular venue encountered or identified.
- the geofencing implementations described herein present educated guesses as to venue context to include with media content created or captured by the computing device 202.
- the venue context includes, for example, information described a venue represented by a geofence the computing device 202 has entered.
- aspects of the disclosure may analyze the check- in history of the user 206 (users 206 often visit particular venues repeatedly) and social check-in data (users 206 are usually with friends if the user 206 is near the friends).
- aspects of the disclosure enable location tracking without giving an application access to a real-time location of the computing device 202.
- the application requests access from the user 206 to know when the user 206 is at home or work. Geofences are then set up for the home and work locations, and notifications are sent to the application when the computing device 202 enters or exits the geofences. The list of geofences may be edited by the user 206.
- At least a portion of the functionality of the various elements in FIG. 2 may be performed by other elements in FIG. 2, or an entity (e.g., processor, web service, server, application program, computing device, etc.) not shown in FIG. 2.
- entity e.g., processor, web service, server, application program, computing device, etc.
- the operations illustrated in FIG. 3 and FIG. 4 may be implemented as software instructions encoded on a computer readable medium, in hardware programmed or designed to perform the operations, or both.
- aspects of the disclosure may be implemented as a system on a chip.
- Exemplary computer readable media include flash memory drives, digital versatile discs (DVDs), compact discs (CDs), floppy disks, and tape cassettes.
- computer readable media comprise computer storage media and communication media.
- Computer storage media store information such as computer readable instructions, data structures, program modules or other data.
- Computer storage media exclude propagated data signals.
- Communication media typically embody computer readable instructions, data structures, program modules, or other data in a modulated data signal such as a carrier wave or other transport mechanism and include any information delivery media.
- embodiments of the invention are operational with numerous other general purpose or special purpose computing system environments or configurations.
- Examples of well-known computing systems, environments, and/or configurations that may be suitable for use with aspects of the invention include, but are not limited to, mobile computing devices, personal computers, server computers, hand-held or laptop devices, multiprocessor systems, gaming consoles, microprocessor-based systems, set top boxes, programmable consumer electronics, mobile telephones, network PCs, minicomputers, mainframe computers, distributed computing environments that include any of the above systems or devices, and the like.
- Embodiments of the invention may be described in the general context of computer-executable instructions, such as program modules, executed by one or more computers or other devices.
- the computer-executable instructions may be organized into one or more computer-executable components or modules.
- program modules include, but are not limited to, routines, programs, objects, components, and data structures that perform particular tasks or implement particular abstract data types.
- aspects of the invention may be implemented with any number and organization of such components or modules. For example, aspects of the invention are not limited to the specific computer-executable instructions or the specific components or modules illustrated in the figures and described herein. Other embodiments of the invention may include different computer-executable instructions or components having more or less functionality than illustrated and described herein.
- inventions illustrated and described herein as well as embodiments not specifically described herein but within the scope of aspects of the invention constitute exemplary means for power-aware tiered geofencing with selectively implementation of the positioning modalities to reduce power consumption of the mobile computing device 104, and exemplary means for delegating a beacon watch list to the first processor 212 while disabling the second processor 212.
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Radar, Positioning & Navigation (AREA)
- Remote Sensing (AREA)
- Signal Processing (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Position Fixing By Use Of Radio Waves (AREA)
- Mobile Radio Communication Systems (AREA)
- Telephone Function (AREA)
Abstract
Embodiments enable geofencing applications and beacon watch lists. A computing device with at least a first processor and a second processor identifies a set of beacons associated with a geofence. The first processor consumes less power when operating than the second processor. The first processor is provided with the identified set of beacons. In beacon watch list embodiments, the first processor detects one or more beacons proximate to the computing device, compares the detected beacons with the provided set of beacons to determine whether the computing device is within the geofence, and updates a location status based on the comparison. In tiered geofencing implementations, the computing device switches among positioning modalities based on a distance from the computing device to the geofence to save power.
Description
POWER-AWARE TIERED GEOFENCTNG AND
BEACON WATCHLISTS
BACKGROUND
[0001] Geofencing may be implemented in existing systems in several ways, one of which relies on location polling. A mobile telephone continually polls for its location and that location is compared to the location of an area of interest to determine whether the mobile telephone is within the area of interest. Example areas of interest may include a home, workplace, or a nearby friend. While effective, the existing systems are battery intensive thus degrading the user experience. For example, many applications request near real-time updates of the location of the mobile telephone even when the mobile telephone is far away from the areas of interest.
SUMMARY
[0002] Embodiments of the disclosure provide power-aware tiered geofencing. A computing device identifies a set of beacons associated with a geofence. The computing device has at least a first processor and a second processor, wherein the first processor consumes less power when operating than the second processor. The first processor is provided with the identified set of beacons. The second processor is disabled while the first processor detects one or more beacons proximate to the computing device using a first one of a plurality of positioning modalities. The first processor further compares the detected beacons with the provided set of beacons to determine whether the computing device is within or nearby the geofence. Based on the comparison, a second one of the plurality of positioning modalities is selected. The second processor is enabled based on the selected second one of the plurality of positioning modalities. The computing device implements the selected second one of the plurality of positioning modalities to detect additional beacons.
[0003] This Summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This Summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used as an aid in determining the scope of the claimed subject matter.
BRIEF DESCRIPTION OF THE DRAWINGS
[0004] FIG. 1 is an exemplary block diagram illustrating a mobile computing device entering and exiting a geofence around a house.
[0005] FIG. 2 is an exemplary block diagram illustrating operation of the computing device to detect beacons and select a positioning modality.
[0006] FIG. 3 is an exemplary flow chart illustrating operation of the computing device to select a positioning modality based on a determined distance from a geofence.
[0007] FIG. 4 is an exemplary flow chart illustrating operation of the computing device to implement beacon watch lists.
[0008] FIG. 5 is an exemplary block diagram illustrating beacon coverage around a geofence.
[0009] FIG. 6 is an exemplary block diagram illustrating cell tower coverage overlapping other beacon coverage near a geofence.
[0010] FIG. 7 is an exemplary chart illustrating coverage of various positioning modalities.
[0011] Corresponding reference characters indicate corresponding parts throughout the drawings.
DETAILED DESCRIPTION
[0012] Referring to the figures, embodiments of the disclosure support power- aware geofencing applications in multi-processor devices. Some embodiments enable real-time or near real-time notifications whenever a computing device 202 enters and/or exits a virtual perimeter defined by a geofence. Further, with tiered geofencing, the computing device 202 (e.g., a mobile computing device 104) saves power by switching among different methods of location determination (e.g., via different positioning modalities) having different levels of power consumption. For example, implementing Wi-Fi or satellite-based positioning consumes more power than implementing cellular- based positioning. The switching is dependent on a current location of the computing device 202, a distance from the computing device 202 to the geofence(s), an error range or accuracy of the positioning modality and/or beacon, the size of the geofences, and/or other factors.
[0013] The geofencing applications may be implemented with or without location determination (e.g., using positioning modalities that may either determine location or detect proximity to beacons 204). In some embodiments, when the computing device 202 is far from the geofence, aspects of the disclosure disable the high power
processor(s) and rely on the low power processor(s) to monitor the location of the computing device 202. When the computing device 202 approaches the geofence, aspects of the disclosure implement higher accuracy methods of monitoring. When the computing device 202 is once again far away from the geofence, the greater power-consuming positioning modalities are disabled again. In this manner, low power and low accuracy positioning modalities are used to determine whether to switch to higher power and higher accuracy positioning modalities, thus reducing power consumption by the computing device 202.
[0014] In some embodiments, rather than calculating and analyzing the location of the computing device 202 to determine whether the computing device 202 is within or nearby a geofence, aspects of the disclosure compare detected proximate beacons 204 to a set of beacons associated with the geofence. In this manner, the entry or exit of the computing device 202 relative to the geofence can be determined by a lower power positioning modality without calculating the actual location of the computing device 202. This allows the higher-power-consumption positioning modalities to remain disabled until a geofence entry event or geofence exit event is triggered, or the device is known to be nearby the geofence. Power is thus conserved over existing methods. A user 206 of the computing device 202 is also able to associate location status privacy settings with the geofence or other beacons 204 (e.g., for sharing location status with other users).
[0015] Referring next to FIG. 1, an exemplary block diagram illustrates the mobile computing device 104 entering and exiting a geofence 102 around a house. In general, the geofence 102 represents a virtual perimeter of a geographic area of interest. While the geofence 102 illustrated in FIG. 2 and elsewhere is represented by a circle, aspects of the disclosure are operable with any size or shape of geofence 102. Aspects of the disclosure are further operable with geofences in both two- and three-dimensions. For example, a geofence may be established around one or more floors of an office building.
[0016] While some aspects of the disclosure disclose the mobile computing device 104 performing operations such as shown in FIG. 3 and FIG. 4, the disclosure is operable with any computing device capable of entering and exiting the geofence. Such an exemplary computing device is described next with reference to FIG. 2.
[0017] Referring next to FIG. 2, an exemplary block diagram illustrates operation of the computing device 202 to detect beacons 204 and select a positioning modality. The computing device 202 (e.g., a mobile telephone) detects or observes one or more of the beacons 204 including cellular towers (or sectors if directional antennas are
employed) such as for cellular division multiple access (CDMA), wireless fidelity (Wi-Fi) access points, satellites, or other wireless access points (WAPs) such as for the Global System for Mobile Communication (GSM) and 4G/Wi-Max via one or more location sensors 213 of the computing device 202. In general, exemplary beacons 204 include cellular towers, base stations, base transceiver stations, base station sites, and/or any other network elements supporting any quantity and type of communication modes. While some embodiments of the disclosure may be described with reference to the beacons 204 implementing protocols such as the 802.11 family of protocols, embodiments of the disclosure are operable with any beacon 204. For example, beacons 204 may include ultrasonic beacons.
[0018] In embodiments that contemplate determining the location of the computing device 208, after selecting the positioning modality, the computing device 202 communicates with a location service 208 via a network 210 to determine the location of the computing device 202. In other embodiments, the location service 208 is part of or otherwise associated with the computing device 202. In such embodiments, the computing device 202 is able to determine the location of the computing device 202 without external communication with the location service 208.
[0019] The location service 208 implements location determination algorithms based on input from the computing device 202. For example, the location service 208 may implement satellite-based positioning, cellular-based positioning, Wi-Fi-based positioning, BLUETOOTH-based positioning, and the like, based on input received from the computing device 202. With beacon-based location determination, a list of nearby beacons 204 (e.g., Wi-Fi beacons or cell towers) is collected. The location of each of the beacons 204 can be looked up using a unique identifier such as an address of each beacon 204. The position of the computing device 202 can be estimated based on the proximity to each of the beacons 204 in the set and the known locations of the beacons 204.
[0020] In the example of FIG. 2, the computing device 202 associated with the user 206 represents a system for power-aware tiered geofencing. The computing device 202 represents any device executing instructions (e.g., as application programs, operating system functionality, or both) to implement the operations and functionality associated with the computing device 202. The computing device 202 may include the mobile computing device 104 or any other portable device. In some embodiments, the mobile computing device 104 includes a mobile telephone, laptop, tablet, computing pad, netbook, gaming device, and/or portable media player. The computing device 202 may
also include less portable devices such as desktop personal computers, kiosks, and tabletop devices. Additionally, the computing device 202 may represent a group of processing units or other computing devices. As described above with reference to FIG. 1, the computing device 202 represents any device capable of entering and exiting the geofence.
[0021] In some embodiments (not shown), the computing device 202 includes a single processor. In other embodiments, the computing device 202 has at least two processors, one or more sensors, and a memory area 216. For example, the processors include a first processor 212 and a second processor 214, where the first processor 212 consumes less power when operating than the second processor 214. For example, the first processor 212 may be a modem processor while the second processor 214 is a primary processor. The first processor 212 may be a processor designed to consume less power than the second processor 214. Alternatively or in addition, the first processor 212 may be a processor similar to the second processor 214 except that the first processor 212 has transitioned to a low power state by, for example, disabling selected hardware functionality (e.g., caches), reducing the clock speed, or any other known method for reducing power consumption.
[0022] An exemplary computing device 202 may have a plurality of processors including a primary processor, a graphics processing unit, a Wi-Fi chipset, a
BLUETOOTH chipset, a cellular modem or radio, and others. Some of the processors consume more power than others, and there may be a power consumption cost incurred when one of the processors switches from a low power state to a higher power state (or vice versa).
[0023] In general, the processors include any quantity of processing units, and are programmed to execute computer-executable instructions for implementing aspects of the disclosure. The instructions may be performed by the processors or by multiple processors executing within the computing device 202, or performed by one or more processors external to the computing device 202. In some embodiments, the processors are programmed to execute instructions such as those illustrated in the figures (e.g., FIG. 3 and FIG. 4).
[0024] The computing device 202 also has one or more location sensors 213 associated therewith. The location sensors 213 may be internal and/or external to the computing device 202. Exemplary location sensors 213 include, but are not limited to, a cellular radio or modem, a GPS receiver, a Wi-Fi adapter or modem, a BLUETOOTH brand communication service element, a three-dimensional motion sensor, or the like.
[0025] The computing device 202 further has one or more computer readable media such as the memory area 216. The memory area 216 includes any quantity of media associated with or accessible by the computing device 202. The memory area 216 may be internal to the computing device 202 (as shown in FIG. 2), external to the computing device 202 (not shown), or both (not shown).
[0026] The memory area 216 stores, among other data, one or more applications 218. The applications 218, when executed by one or more of the processors, operate to perform functionality on the computing device 202. Exemplary applications 218 include mail application programs, web browsers, calendar application programs, address book application programs, messaging programs, media applications, location-based services, search programs, and the like. The applications 218 may communicate with counterpart applications or services such as web services accessible via the network 210. For example, the applications 218 may represent downloaded client-side applications that correspond to server-side services executing in a cloud.
[0027] In some embodiments, one or more of the applications 218 rely on information describing a location of the computing device 202. The location may represent a status (e.g., inside and/or outside the geofence) or an actual determination location (e.g., coordinates). The applications may perform particular actions based on the determined location of the computing device 202 relative to the geofence. Examples of the execution of such applications are described below.
[0028] The memory area 216 further stores accuracy thresholds corresponding to the positioning modalities and/or the beacons. The accuracy thresholds are defined based on implementation of the various positioning modalities (e.g., an error range or accuracy value) and, in some embodiments, the size of the geofence. In some embodiments, the positioning modalities correspond to the location sensors 213. For example, the positioning modalities include cellular-based positioning, satellite-based positioning, Wi- Fi-based positioning, and BLUETOOTH -based positioning.
[0029] Each of the positioning modalities has one of the accuracy thresholds 222 associated therewith. In some embodiments, the accuracy threshold 222 represents a range or accuracy of the positioning modality. In other embodiments, the accuracy threshold 222 represents a range or accuracy of a particular beacon or beacon type.
Exemplary accuracy thresholds 222 include approximately two kilometers for cellular- based location determination, approximately 250 meters for Wi-Fi-based location determination, and approximately five meters for satellite-based location determination.
The accuracy threshold 222 may be defined based on empirical data from the computing device 202 or other computing devices (e.g., based on a success rate of previous applications or implementations of the positioning modality).
[0030] The memory area 216 further stores one or more computer-executable components. Exemplary components include a geofence component 224, a sensor component 226, a boundary component 228, a location component 230, and a privacy component 232. Operation of the components, when executed, is described below with reference to FIG. 4.
[0031] Referring next to FIG. 3, an exemplary flow chart illustrates operation of the computing device 202 to select a positioning modality based on a determined distance from the geofence 102. In other embodiments (e.g. see FIG. 4), distance from the geofence 102 is not explicitly determined, but whether the computing device 202 is within, nearby and potentially inside, or not inside the geofence 102.
[0032] At 302, the computing device 202 identifies a set of beacons associated with the geofence 102 or other area of interest. For example, the computing device 202 may identify one or more beacons 204 having a radius that overlaps with or is contained within a geographic area associated with the geofence 102.
[0033] In some embodiments, the computing device 202 queries the location service 208 or another entity (e.g., a cloud service) to obtain the set of beacons and store the set of beacons on the computing device 202. In some embodiments, the location service 208 maintains a beacon database (e.g., or in a file or in memory) that includes the approximate location and range of each beacon 204. Based on the location of the geofence(s) of interest, the location service 208 can query or filter the beacon database to identify the beacons 204 that intersect or are contained within the geofence 102.
Alternatively or in addition, the computing device 202 may access the memory area 216 to build the set of beacons. The set of beacons may include beacons 204 of any type (e.g., cellular, Wi-Fi, etc.) and of any combination of types.
[0034] In some embodiments, the identified set of beacons represents possible areas of interest to the user 206, and may include a plurality of geofences 102. The set of beacons may also be referred to as a beacon watch list.
[0035] At 304, the set of beacons is provided to the first processor 212 or another low power processor. For example, the first processor 212 may be provided a pointer or register value indicating where the set of beacons is available for access. At 306, the second processor 214, or any other processor consuming more power than the first
processor 212, is disabled to reduce power consumption. Disabling the second processor 214 includes, for example, de-energizing the second processor 214, setting the second processor 214 to a low power mode, or otherwise adjusting the second processor 214 to consume less power. In this manner, the second processor 214 may be disabled indefinitely until enabled as described below.
[0036] After receiving or being notified of the set of beacons, the first processor 212 determines a distance from the computing device 202 to the geofence 102 at 308. For example, the first processor 212 obtains a location of the computing device 202 using one of the positioning modalities capable of implementation by the first processor 212. The first processor 212 compares the location of the computing device 202 with the locations and/coverage of the beacons 204 in the set of beacons defining the geofence 102 to calculate the distance from the computing device 202 to the geofence 102. The computing device 202 may be moving towards the geofence 102, moving away from the geofence 102, or stationary.
[0037] For example, at 310, the first processor 212 compares the determined distance with the accuracy thresholds 222 associated with each of the positioning modalities, or associated with the particular location determination fix (e.g., from 308). At 312, based on the comparison, the first processor 212 selects one of the positioning modalities. In some embodiments, the first processor 212 selects one or more of the positioning modalities having accuracy thresholds 222 that are greater than the determined distance. For example, if the determined distance is greater than the accuracy threshold 222 using a first one of the positioning modalities but less than the accuracy threshold 222 using a second one of the positioning modalities, then the first processor 212 selects the first positioning modality. In some embodiments, if the difference between the determined distance and one of the accuracy thresholds 222 is a small value such that the moving computing device 202 may be within or nearby the accuracy threshold 222 soon, the first processor 212 may switch to a positioning modality with a smaller accuracy threshold 222 (e.g., higher accuracy).
[0038] The first processor 212 identifies the processor(s) needed for
implementing the selected positioning modality to determine whether to enable the second processor 214 at 314. If the positioning modality is the same positioning modality employed at 308, the second processor 214 is not enabled. Otherwise, if the first processor 212 determines that the second processor 214 should be enabled at 314, the second processor 214 is enabled at 316. For example, the first processor 212 may send a
notification to the second processor 214 to enable the second processor 214. While discussed in the context of the first processor 212 and the second processor 214, aspects of the disclosure are operable with any quantity of processors.
[0039] At 318, the location of the computing device 202 is determined using the selected positioning modality. For example, at least the second processor 214 proceeds to perform operations 308, 310, 312, 314, and 316 (in some cases).
[0040] In some embodiments, the computing device 202 calculates or receives a success rate associated with use of the selected positioning modality. The success rate may be represented as a value indicating whether a location could be determined, a radius of error associated with the determined location, speed of the fix, or another metric. In such embodiments, the computing device 202 analyzes the success rate and may adjust any of the accuracy thresholds 222 to be greater or less depending on the success rate.
[0041] Referring next to FIG. 4, an exemplary flow chart illustrates operation of the computing device 202 to implement beacon watch lists. In some embodiments, the operations illustrated in FIG. 4 are performed using a beacon watch list and without determining a location of the computing device 202. In contrast to polling for the location of the computing device 202 (e.g., such as in FIG. 3), the beacon watch list enables a geofencing implementation with reduced power consumption by the computing device 202 due to the lack of location polling. At 402, the computing device 202 identifies a set of beacons associated with the geofence 102. For example, the computing device 202 may query the location service 208 or another entity to obtain the set of beacons. At 404, the set of beacons is provided to the first processor 212 or another low power processor. At 406, the second processor 214, or any other processor consuming more power than the first processor 212, is disabled to reduce power consumption.
[0042] After receiving or being notified of the set of beacons, the first processor
212 detects one or more beacons 204 proximate to the computing device 202 at 408 using a first positioning modality (e.g., cellular-based). The first processor 212 compares the detected beacons 204 with the set of beacons associated with the geofence 102 at 410 to determine if the computing device 202 is within or nearby the geofence 102. For example, the first processor 212 determines if one of the detected beacons 204 is also part of the set of beacons. If one of the detected beacons 204 is also in the set of beacons, the first processor 212 determines whether the range or coverage area of that beacon 204 is entirely within the geofence 102. If so, the first processor 212 concludes that the computing device 202 is within the geofence 102. The first processor 212 may instead determine that
the range of the beacon 204 is partly within the geofence 102 and that the range is within a margin of error. If so, the first processor 212 concludes that the computing device 202 is within the geofence 102. The first processor 212 may instead determine that the range of the beacon 204 is partly within the geofence 102 and that the range is greater than the margin of error. If so, the first processor 212 concludes that a different beacon type with greater accuracy (e.g., Wi-Fi instead of cellular) should be detected to determine whether the computing device 202 is within the geofence 102 (e.g., see operations 314, 316, and 318 in FIG. 3).
[0043] If the first processor 212 determines that the computing device 202 is not within or nearby the geofence 102 at 412, the first processor 212 subsequently re-performs operations 408, 410, and 412 using the same positioning modality (e.g., the first positioning modality). For example, the first processor 212 may detect other beacons 204 after a predefined time period elapses (e.g., every ten seconds, every five minutes, every hour, etc.). In another example, the first processor 212 may reduce the frequency of re- performing the operations (e.g., by a back-off factor or amount). In some embodiments, the frequency reduction is tied to a determination or signal that the user 206 is stationary (e.g., based on detecting the same set of beacons more than once, or based on
accelerometer data).
[0044] If the first processor 212 determines that the computing device 202 is within or nearby the geofence 102 at 412, the first processor 212 selects a second positioning modality (e.g., Wi-Fi-based) at 414. If the second processor 214 is needed for implementation of the selected second positioning modality, the second processor 214 is enabled at 416. Enabling the second processor 214 includes, but is not limited to, energizing the second processor 214, setting or configuring the second processor 214 to a higher power or full power mode, adjusting the second processor 214 to consume more power, waking the second processor 214, or interrupting the second processor 214.
[0045] The computing device 202 detects additional beacons (e.g., of the type corresponding to the second positioning modality) at 418 to enable location determination with greater accuracy.
[0046] Further, the computing device 202 may perform any operation associated with entry into, or exit from, the geofence 102. For example, the computing device 202 may update a location status based on whether or not the computing device 202 is within the geofence 102. In some embodiments, the computing device 202 updates the location
status after determining whether the computing device 202 is within or nearby the geofence 102 at 412, and without performing operations 414, 416, or 418.
[0047] In another example, the computing device 202 may create a tag for association with content (e.g., photos) created or captured by the computing device 202 while within the geofence 102. The tag provides context information based on the updated location status. The tag may be created from user data stored on the computing device 202 (e.g., from data provided by the user 206 describing the geofence 102), or may be created from data obtained from another source such as the Internet.
[0048] In some embodiments, the computer-executable components illustrated in FIG. 2 are executed by the first processor 212 or the second processor 214 to perform the operation illustrated in FIG. 4. For example, the geofence component 224, when executed by the first processor 212, causes the first processor 212 to identify the set of beacons associated with the geofence 102. The sensor component 226, when executed by the first processor 212, causes the first processor 212 to detect one or more beacons 204 proximate to the computing device 202. The boundary component 228, when executed by the first processor 212, causes the first processor 212 to compare the beacons 204 detected by the sensor component 226 with the set of beacons identified by the geofence component 224 to determine whether the computing device 202 is within or nearby the geofence 102. In some embodiments, the geofence component 224, the sensor component 226, and the boundary component 228 execute while the second processor 214 is disabled. The location component 230, when executed by the first processor 212, causes the first processor 212 to enable the second processor 214 based on whether the computing device is within or nearby the geofence 102 as determined by the boundary component 228. In some embodiments, at least the second processor 214 executes to detect additional beacons to update a location status of the computing device 202.
[0049] In some embodiments, the privacy component 232, when executed by the computing device 202, enables the user 206 to set privacy settings. The privacy settings may be based on the location status (e.g., whether or not the computing device 202 is within the geofence 102). For example, the user 206 may specify that information describing whether or not the computing device 202 is within one of the geofences 102 may be shared, but that real-time tracking information for the computing device 202 may not be shared.
[0050] Referring next to FIG. 5, an exemplary block diagram illustrates beacon coverage around a geofence. In the example of FIG. 5, the circle indicated by the solid line represents the geofence. The other circles represent the range and position of beacons 204 that intersect or are contained within the geofence. In particular, the circles with the horizontal Crosshatch pattern represent beacons 204 whose coverage overlaps with the geofence (e.g., part of the coverage is within the geofence, while the rest of the coverage is outside the geofence). The computing device 202 encounters these beacons 204 first as the computing device 202 approaches the geofence, and these beacons 204 last as the computing device 202 exits the geofence. The circles with the vertical Crosshatch pattern represent beacons 204 whose coverage is contained entirely within the geofence. In the example of FIG. 5, the beacons 204 may be Wi-Fi beacons.
[0051] While the beacon coverage is represented by circles in FIG. 5 and elsewhere in the disclosure, actual beacon coverage differs among the beacons 204 and may take any form or shape.
[0052] Referring next to FIG. 6, an exemplary block diagram illustrates cell tower coverage overlapping other beacon coverage near a geofence. In the example of FIG. 6, the small circles represent Wi-Fi beacons while the large circles (e.g., circle 602) represent cell towers with a broader coverage area (e.g., error radius) than the Wi-Fi beacons. The four cell towers and the Wi-Fi beacons are included in a beacon watch list stored by the computing device 202. As the computing device 202 approaches, the computing device 202 applies a cell-based positioning modality to detect proximate cell towers (e.g., a Wi-Fi modem is powered off to save power). If the computing device 202 is connected to a cell tower other than one of the four cell towers on the beacon watch list, the computing device 202 concludes that it is not near the geofence and that the Wi-Fi modem should remain powered off.
[0053] If the computing device 202 is connected to one of the four cell towers on the beacon watch list, the computing device 202 concludes that it may be near or within the geofence, but that a positioning modality with a higher accuracy (e.g., a smaller accuracy threshold 222, or a smaller margin of error) for location determination should be employed. As such, the computing device 202 then powers on the Wi-Fi modem to detect proximate Wi-Fi beacons (e.g., in addition to detecting proximate cell towers). Once the computing device 202 is no longer connected to one of the four cell towers, the computing device 202 powers off the Wi-Fi modem to conserve power and only uses the cellular radio to detect proximate beacons 204.
[0054] Referring next to FIG. 7, an exemplary chart illustrates coverage of various positioning modalities. Aspects of the disclosure are operable to switch among any known or future positioning modality. The exemplary modalities illustrated in FIG. 7 include satellite communication systems (e.g., GPS and assisted GPS), Wi-Fi
communication systems, cellular communication systems (e.g., multi cell and single cell), and Internet protocol (IP) address-based positioning systems. With IP address-based positioning systems, the IP address of the user 206 is used to determine the region of the user 206.
[0055] Per the chart, the accuracy of the positioning modality decreases as the distance increases along the horizontal axis of the chart.
Additional Examples
[0056] Various geofencing applications are supported by aspects of the disclosure. In one example, the computing device 202 conserves power while providing real-time location tracking. In this example, because many users 206 are stationary or within a small set of locations (e.g., home, work, school) for a large part of the day, the geofencing implementation described in the disclosure conserves power by disabling realtime tracking hardware (e.g., GPS) upon entry to a geofence and enabling the real-time tracking hardware upon leaving the geofence.
[0057] In another example, aspects of the disclosure enable the user 206 to automatically "check- in" and automatically "check-out" from a venue (e.g., a coffee shop, store, restaurant, etc.) using the geofencing implementations described herein. In this example, a geofence is defined for each venue. In some embodiments, the user 206 is presented with an option to allow automatic check- in and/or check-out from each particular venue encountered or identified.
[0058] In yet another example, the geofencing implementations described herein present educated guesses as to venue context to include with media content created or captured by the computing device 202. The venue context includes, for example, information described a venue represented by a geofence the computing device 202 has entered. To improve the relevancy of the venue context, aspects of the disclosure may analyze the check- in history of the user 206 (users 206 often visit particular venues repeatedly) and social check-in data (users 206 are usually with friends if the user 206 is near the friends).
[0059] In still another example, aspects of the disclosure enable location tracking without giving an application access to a real-time location of the computing device 202. For example, the application requests access from the user 206 to know when the user 206 is at home or work. Geofences are then set up for the home and work locations, and notifications are sent to the application when the computing device 202 enters or exits the geofences. The list of geofences may be edited by the user 206.
[0060] At least a portion of the functionality of the various elements in FIG. 2 may be performed by other elements in FIG. 2, or an entity (e.g., processor, web service, server, application program, computing device, etc.) not shown in FIG. 2.
[0061] In some embodiments, the operations illustrated in FIG. 3 and FIG. 4 may be implemented as software instructions encoded on a computer readable medium, in hardware programmed or designed to perform the operations, or both. For example, aspects of the disclosure may be implemented as a system on a chip.
[0062] While no personally identifiable information is tracked by aspects of the disclosure, embodiments have been described with reference to data monitored and/or collected from users 206. In such embodiments, notice is provided to the users 206 of the collection of the data (e.g., via a dialog box or preference setting) and users 206 are given the opportunity to give or deny consent for the monitoring and/or collection. The consent may take the form of opt-in consent or opt-out consent.
Exemplary Operating Environment
[0063] Exemplary computer readable media include flash memory drives, digital versatile discs (DVDs), compact discs (CDs), floppy disks, and tape cassettes. By way of example and not limitation, computer readable media comprise computer storage media and communication media. Computer storage media store information such as computer readable instructions, data structures, program modules or other data. Computer storage media exclude propagated data signals. Communication media typically embody computer readable instructions, data structures, program modules, or other data in a modulated data signal such as a carrier wave or other transport mechanism and include any information delivery media.
[0064] Although described in connection with an exemplary computing system environment, embodiments of the invention are operational with numerous other general purpose or special purpose computing system environments or configurations. Examples of well-known computing systems, environments, and/or configurations that may be suitable for use with aspects of the invention include, but are not limited to, mobile
computing devices, personal computers, server computers, hand-held or laptop devices, multiprocessor systems, gaming consoles, microprocessor-based systems, set top boxes, programmable consumer electronics, mobile telephones, network PCs, minicomputers, mainframe computers, distributed computing environments that include any of the above systems or devices, and the like.
[0065] Embodiments of the invention may be described in the general context of computer-executable instructions, such as program modules, executed by one or more computers or other devices. The computer-executable instructions may be organized into one or more computer-executable components or modules. Generally, program modules include, but are not limited to, routines, programs, objects, components, and data structures that perform particular tasks or implement particular abstract data types.
Aspects of the invention may be implemented with any number and organization of such components or modules. For example, aspects of the invention are not limited to the specific computer-executable instructions or the specific components or modules illustrated in the figures and described herein. Other embodiments of the invention may include different computer-executable instructions or components having more or less functionality than illustrated and described herein.
[0066] Aspects of the invention transform a general-purpose computer into a special-purpose computing device when configured to execute the instructions described herein.
[0067] The embodiments illustrated and described herein as well as embodiments not specifically described herein but within the scope of aspects of the invention constitute exemplary means for power-aware tiered geofencing with selectively implementation of the positioning modalities to reduce power consumption of the mobile computing device 104, and exemplary means for delegating a beacon watch list to the first processor 212 while disabling the second processor 212.
[0068] The order of execution or performance of the operations in embodiments of the invention illustrated and described herein is not essential, unless otherwise specified. That is, the operations may be performed in any order, unless otherwise specified, and embodiments of the invention may include additional or fewer operations than those disclosed herein. For example, it is contemplated that executing or performing a particular operation before, contemporaneously with, or after another operation is within the scope of aspects of the invention.
[0069] When introducing elements of aspects of the invention or the
embodiments thereof, the articles "a," "an," "the," and "said" are intended to mean that there are one or more of the elements. The terms "comprising," "including," and "having" are intended to be inclusive and mean that there may be additional elements other than the listed elements.
[0070] Having described aspects of the invention in detail, it will be apparent that modifications and variations are possible without departing from the scope of aspects of the invention as defined in the appended claims. As various changes could be made in the above constructions, products, and methods without departing from the scope of aspects of the invention, it is intended that all matter contained in the above description and shown in the accompanying drawings shall be interpreted as illustrative and not in a limiting sense.
Claims
1. A system for power-aware tiered geofencing, said system comprising:
a memory area associated with a mobile computing device, said memory area storing accuracy thresholds each associated with at least one of a plurality of positioning modalities; and
a first processor programmed to disable a second processor, wherein the first processor consumes less power when operating than the second processor, and wherein the first processor is further programmed to perform the following operations while the second processor is disabled:
determine a distance from the mobile computing device to a geofence using one of the positioning modalities;
compare the determined distance with the accuracy threshold associated with said one of the positioning modalities;
select at least one of the plurality of positioning modalities based on the comparison; and
enable the second processor based on the selected positioning modality, wherein the mobile computing device implements the selected positioning modality to detect additional beacons.
2. The system of claim 1, wherein the mobile computing device defines each of the accuracy thresholds based on an accuracy of the positioning modality and a size of the geofence, and wherein the first processor is further programmed to adjust the accuracy thresholds for the positioning modalities based on observed success rates during prior use of the positioning modalities.
3. The system of claim 1, wherein the second processor is programmed to implement the selected positioning modality to determine a distance from the mobile computing device to the geofence, and wherein the first processor is programmed to compare the determined distance with the accuracy threshold to determine whether the mobile computing device is inside the geofence and/or outside the geofence.
4. The system of claim 1 , further comprising:
means for power-aware tiered geofencing with selectively implementation of the positioning modalities to reduce power consumption of the mobile computing device; and means for delegating a beacon watch list to the first processor while disabling the second processor.
5. A method comprising:
identifying, by a computing device, a set of beacons associated with a geofence, said computing device having at least a first processor and a second processor, wherein the first processor consumes less power when operating than the second processor; and
providing the first processor with the identified set of beacons;
disabling the second processor, wherein the first processor performs the following operations while the second processor is disabled:
detecting one or more beacons proximate to the computing device using a first one of a plurality of positioning modalities;
comparing the detected beacons with the provided set of beacons to determine whether the computing device is within or nearby the geofence;
based on the comparison, selecting a second one of the plurality of positioning modalities; and
enabling the second processor based on the selected second one of the plurality of positioning modalities, wherein the computing device implements the selected second one of the plurality of positioning modalities to detect additional beacons.
6. The method of claim 5, wherein identifying the set of beacons associated with the geofence comprises identifying one or more beacons having a radius that overlaps with or is contained within the geofence, and wherein providing the first processor with the identified set of beacons comprises providing a modem processor with the identified set of beacons.
7. The method of claim 5, wherein identifying the set of beacons associated with the geofence comprises:
receiving the set of beacons from a cloud service; and
storing the received set of beacons on the computing device.
8. The method of claim 5, wherein disabling the second processor comprises instructing the second processor to enter a low power mode and/or de-energizing the second processor, and wherein enabling the second processor comprises one or more of the following operations: waking the second processor, energizing the second processor, and interrupting the second processor.
9. The method of claim 5, further comprising:
updating a location status based on whether the computing device is within the geofence; and
tagging media content created by the computing device within the geofence with context based on the updated location status.
10. The method of claim 5, wherein one or more computer storage media embody computer-executable components, said computer storage media being associated with a computing device having at least a first processor and a second processor, said components comprising:
a geofence component that when executed causes the first processor to identify a set of beacons associated with a geofence, wherein the first processor consumes less power than the second processor when operating;
a sensor component that when executed causes the first processor to detect one or more beacons proximate to the computing device;
a boundary component that when executed causes the first processor to compare the beacons detected by the sensor component with the set of beacons identified by the geofence component to determine whether the computing device is within or nearby the geofence, wherein said geofence component, said sensor component, and said boundary component execute while the second processor is disabled; and
a location component that when executed causes the first processor to enable the second processor based on whether the computing device is within or nearby the geofence as determined by the boundary component, wherein at least the second processor executes to detect additional beacons to update a location status of the computing device.
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
EP12840466.2A EP2767125B1 (en) | 2011-10-13 | 2012-10-12 | Power-aware tiered geofencing and beacon watchlists |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US13/272,241 US8810454B2 (en) | 2011-10-13 | 2011-10-13 | Power-aware tiered geofencing and beacon watchlists |
US13/272,241 | 2011-10-13 |
Publications (1)
Publication Number | Publication Date |
---|---|
WO2013056145A1 true WO2013056145A1 (en) | 2013-04-18 |
Family
ID=47697773
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
PCT/US2012/060091 WO2013056145A1 (en) | 2011-10-13 | 2012-10-12 | Power-aware tiered geofencing and beacon watchlists |
Country Status (4)
Country | Link |
---|---|
US (1) | US8810454B2 (en) |
EP (1) | EP2767125B1 (en) |
CN (1) | CN102938927B (en) |
WO (1) | WO2013056145A1 (en) |
Cited By (17)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
EP2790385A1 (en) * | 2013-04-08 | 2014-10-15 | Samsung Electronics Co., Ltd. | Electronic device and method for receiving geo-fence service with low power consumption |
WO2014200523A1 (en) * | 2013-06-14 | 2014-12-18 | Microsoft Corporation | Coalescing geo-fence events |
EP2889578A1 (en) * | 2013-12-30 | 2015-07-01 | 9Solutions Oy | Indoor system for providing navigation data |
CN105611983A (en) * | 2014-03-25 | 2016-05-25 | 华为终端有限公司 | Mail processing method and apparatus |
WO2016085605A1 (en) | 2014-11-26 | 2016-06-02 | Intel Corporation | Virtual sensor apparatus and method |
EP3041275A1 (en) * | 2015-01-05 | 2016-07-06 | SK Planet Co., Ltd. | Apparatus and method for activating wireless communication function automatically for geo-fence, system comprising the same and non-transitory computer readable storage medium having computer program recorded thereon |
EP3131317A1 (en) * | 2015-08-12 | 2017-02-15 | Samsung Electronics Co., Ltd. | Method and apparatus for providing location information |
EP3063996A4 (en) * | 2014-07-02 | 2017-04-12 | MediaTek Inc. | Mobile communication devices and context-based geofence control methods thereof |
EP3143814A4 (en) * | 2014-05-16 | 2018-01-24 | Google LLC | Running location provider processes |
US9880604B2 (en) | 2011-04-20 | 2018-01-30 | Microsoft Technology Licensing, Llc | Energy efficient location detection |
US9922531B1 (en) | 2016-12-21 | 2018-03-20 | Tile, Inc. | Safe zones in tracking device environments |
WO2018080588A1 (en) * | 2016-10-31 | 2018-05-03 | Intuit Inc. | Battery efficient automatic mileage tracking |
US9998866B2 (en) | 2013-06-14 | 2018-06-12 | Microsoft Technology Licensing, Llc | Detecting geo-fence events using varying confidence levels |
CN108882207A (en) * | 2017-05-08 | 2018-11-23 | 阿里巴巴集团控股有限公司 | The implementation method and device of near field Trigger Function |
EP2595418B1 (en) * | 2011-11-18 | 2019-05-01 | Samsung Electronics Co., Ltd | Method and apparatus for providing an alert on a user equipment entering an alerting area |
FR3126173A1 (en) * | 2021-08-12 | 2023-02-17 | Follower Products | Method for tracking a goods journey |
WO2023049905A1 (en) * | 2021-09-24 | 2023-03-30 | Accretive Media LLC | Automated measurement and analytics software for out of home content delivery |
Families Citing this family (97)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7534169B2 (en) | 2005-07-08 | 2009-05-19 | Cfph, Llc | System and method for wireless gaming system with user profiles |
US8616967B2 (en) | 2004-02-25 | 2013-12-31 | Cfph, Llc | System and method for convenience gaming |
US10510214B2 (en) | 2005-07-08 | 2019-12-17 | Cfph, Llc | System and method for peer-to-peer wireless gaming |
US9306952B2 (en) | 2006-10-26 | 2016-04-05 | Cfph, Llc | System and method for wireless gaming with location determination |
US9411944B2 (en) | 2006-11-15 | 2016-08-09 | Cfph, Llc | Biometric access sensitivity |
US9183693B2 (en) | 2007-03-08 | 2015-11-10 | Cfph, Llc | Game access device |
US8956231B2 (en) | 2010-08-13 | 2015-02-17 | Cfph, Llc | Multi-process communication regarding gaming information |
DE102011084569B4 (en) * | 2011-10-14 | 2019-02-21 | Continental Automotive Gmbh | Method for operating an information technology system and information technology system |
TW201838697A (en) | 2012-02-28 | 2018-11-01 | 美商Cfph有限責任公司 | Method and apparatus for providing gaming service |
US10200751B2 (en) * | 2012-03-30 | 2019-02-05 | The Nielsen Company (Us), Llc | Methods, apparatus, and machine readable storage media to monitor a media presentation |
US9219983B2 (en) | 2012-05-01 | 2015-12-22 | Qualcomm Incorporated | Mechanism to reduce missing breach detection in geofencing solution |
WO2013173985A1 (en) * | 2012-05-23 | 2013-11-28 | Honeywell International Inc. | Portable electronic devices having a separate location trigger unit for use in controlling an application unit |
US10360760B2 (en) | 2012-06-22 | 2019-07-23 | Zonal Systems, Llc | System and method for placing virtual geographic zone markers |
US10657768B2 (en) | 2012-06-22 | 2020-05-19 | Zonal Systems, Llc | System and method for placing virtual geographic zone markers |
US9317996B2 (en) | 2012-06-22 | 2016-04-19 | II Robert L. Pierce | Method for authenticating a wager using a system and method for interacting with virtual geographic zones |
US9215560B1 (en) * | 2012-07-12 | 2015-12-15 | two forty four a.m. LLC | System and method for device-centric location detection and geofencing |
US9247378B2 (en) | 2012-08-07 | 2016-01-26 | Honeywell International Inc. | Method for controlling an HVAC system using a proximity aware mobile device |
US9769604B2 (en) | 2012-08-22 | 2017-09-19 | Ebay Inc. | Passive dynamic geofencing for mobile devices |
JP6069952B2 (en) * | 2012-08-24 | 2017-02-01 | 富士通株式会社 | Positioning method of mobile terminal device, control program, mobile terminal device |
US9386405B2 (en) * | 2012-08-25 | 2016-07-05 | T-Mobile Usa, Inc. | Location-based profiles |
US20140085084A1 (en) * | 2012-09-27 | 2014-03-27 | Loran Technologies, Inc | Passive active battery saver tracking system |
US9635500B1 (en) * | 2012-10-16 | 2017-04-25 | Intuit Inc | Adaptive geolocation of users to facilitate use of geofences |
US8977288B2 (en) * | 2012-11-16 | 2015-03-10 | Broadcom Corporation | Apparatus and method for performing low-power geo-fence operations |
US9329701B2 (en) | 2012-11-21 | 2016-05-03 | Google Technology Holdings LLC | Low power management of multiple sensor chip architecture |
US10993204B2 (en) | 2013-03-15 | 2021-04-27 | Nextnav, Llc | Systems and methods for determining if a receiver is inside or outside a building or area |
US9326105B2 (en) * | 2013-03-15 | 2016-04-26 | Nextnav, Llc | Systems and methods for using three-dimensional location information to improve location services |
US9113300B2 (en) * | 2013-03-15 | 2015-08-18 | Apple Inc. | Proximity fence |
US9544728B2 (en) * | 2013-03-15 | 2017-01-10 | Intel Corporation | Systems and methods for approximating geo-fencing locations |
AU2014253684B2 (en) | 2013-04-18 | 2017-06-15 | Bluedot Innovation Pty Ltd | Reactive hybrid location determination method and apparatus |
US9191832B2 (en) * | 2013-06-06 | 2015-11-17 | Apple Inc. | Category-based fence |
US9307358B2 (en) * | 2013-06-09 | 2016-04-05 | Apple Inc. | Non-intrusive region notification |
US20140370909A1 (en) * | 2013-06-14 | 2014-12-18 | Microsoft Corporation | Reduced power location determinations for detecting geo-fences |
US8755824B1 (en) * | 2013-06-28 | 2014-06-17 | Google Inc. | Clustering geofence-based alerts for mobile devices |
US10452036B2 (en) | 2013-09-27 | 2019-10-22 | Siemens Industry, Inc. | System and method for deterministic calculation of recovery time for an environmental system |
US20150094860A1 (en) * | 2013-09-27 | 2015-04-02 | Siemens Industry, Inc. | Use of a geo-fencing perimeter for energy efficient building control |
CN104678420A (en) * | 2013-11-26 | 2015-06-03 | 中兴通讯股份有限公司 | Location method, device and terminal |
US20150159895A1 (en) | 2013-12-11 | 2015-06-11 | Honeywell International Inc. | Building automation system with user defined lifestyle macros |
US9313320B2 (en) * | 2014-02-19 | 2016-04-12 | Qualcomm Incorporated | Automatic switching of modes and mode control capabilities on a wireless communication device |
EP3120315B1 (en) | 2014-03-17 | 2019-04-03 | Bleachr LLC | Geofenced event-based fan networking |
US10318990B2 (en) * | 2014-04-01 | 2019-06-11 | Ebay Inc. | Selecting users relevant to a geofence |
US9288620B2 (en) * | 2014-04-01 | 2016-03-15 | Qualcomm Incorporated | Reducing overlapping geofences |
US9338598B2 (en) | 2014-07-09 | 2016-05-10 | Samsung Electronics Co., Ltd | Geo-fence solver |
US9456305B2 (en) * | 2014-07-13 | 2016-09-27 | Intel IP Corporation | Apparatus, system and method of selecting location providers |
US10510193B2 (en) | 2014-08-12 | 2019-12-17 | SVR Tracking, Inc. | Method and system for geofencing of vehicle impound yards |
US20160073264A1 (en) * | 2014-09-05 | 2016-03-10 | Alcatel Lucent | Distributed and mobile virtual fences |
US9521513B2 (en) * | 2014-10-21 | 2016-12-13 | Earthsweep Llc | Method and system of zone suspension in electronic monitoring |
US10740718B2 (en) | 2014-12-01 | 2020-08-11 | Curbside, Inc. | Limited location tracking of a user device for local pickup |
US9648457B2 (en) * | 2014-12-16 | 2017-05-09 | Intel Corporation | Multi-signal geometric location sensing for access control |
WO2016095120A1 (en) | 2014-12-17 | 2016-06-23 | 华为技术有限公司 | Geo-fencing implementation method and mobile device |
CN104703147B (en) * | 2015-01-15 | 2018-05-18 | 小米科技有限责任公司 | Method for sending information and device |
US9900174B2 (en) | 2015-03-06 | 2018-02-20 | Honeywell International Inc. | Multi-user geofencing for building automation |
CN107079397B (en) * | 2015-03-06 | 2020-10-30 | 夏普株式会社 | Mobile terminal, control method for mobile terminal, and recording medium |
US9967391B2 (en) | 2015-03-25 | 2018-05-08 | Honeywell International Inc. | Geo-fencing in a building automation system |
US10802469B2 (en) | 2015-04-27 | 2020-10-13 | Ademco Inc. | Geo-fencing with diagnostic feature |
US9609478B2 (en) | 2015-04-27 | 2017-03-28 | Honeywell International Inc. | Geo-fencing with diagnostic feature |
US10802459B2 (en) | 2015-04-27 | 2020-10-13 | Ademco Inc. | Geo-fencing with advanced intelligent recovery |
US10257782B2 (en) | 2015-07-30 | 2019-04-09 | Google Llc | Power management by powering off unnecessary radios automatically |
US9894475B2 (en) * | 2015-10-20 | 2018-02-13 | Perfect Sense, Inc. | Micro-location monitoring techniques |
US9860256B2 (en) | 2015-11-02 | 2018-01-02 | Box, Inc. | Geofencing of data in a cloud-based environment |
US10057110B2 (en) | 2015-11-06 | 2018-08-21 | Honeywell International Inc. | Site management system with dynamic site threat level based on geo-location data |
US10516965B2 (en) | 2015-11-11 | 2019-12-24 | Ademco Inc. | HVAC control using geofencing |
US9628951B1 (en) | 2015-11-11 | 2017-04-18 | Honeywell International Inc. | Methods and systems for performing geofencing with reduced power consumption |
US9560482B1 (en) | 2015-12-09 | 2017-01-31 | Honeywell International Inc. | User or automated selection of enhanced geo-fencing |
US9860697B2 (en) | 2015-12-09 | 2018-01-02 | Honeywell International Inc. | Methods and systems for automatic adjustment of a geofence size |
CN106998531A (en) * | 2016-01-26 | 2017-08-01 | 中兴通讯股份有限公司 | Mobile user data acquisition method, apparatus and system |
US10605472B2 (en) | 2016-02-19 | 2020-03-31 | Ademco Inc. | Multiple adaptive geo-fences for a building |
US10475144B2 (en) | 2016-02-26 | 2019-11-12 | Microsoft Technology Licensing, Llc | Presenting context-based guidance using electronic signs |
US11423417B2 (en) | 2016-03-09 | 2022-08-23 | Positioning Universal, Inc. | Method and system for auditing and verifying vehicle identification numbers (VINs) on transport devices with audit fraud detection |
US10896429B2 (en) | 2016-03-09 | 2021-01-19 | Talon Systems Software, Inc. | Method and system for auditing and verifying vehicle identification numbers (VINs) with crowdsourcing |
US10796317B2 (en) | 2016-03-09 | 2020-10-06 | Talon Systems Software, Inc. | Method and system for auditing and verifying vehicle identification numbers (VINs) with audit fraud detection |
US9826353B2 (en) | 2016-03-24 | 2017-11-21 | Qualcomm Incorporated | Methods and systems for priority based geofences |
US9998853B2 (en) * | 2016-04-01 | 2018-06-12 | Microsoft Technology Licensing, Llc | Dynamically managing a listen list of beacon aware devices |
WO2017173476A1 (en) * | 2016-04-07 | 2017-10-12 | Bluedot Innovation Pty Ltd | Application of data structures to geo-fencing applications |
KR102498362B1 (en) * | 2016-05-03 | 2023-02-10 | 삼성전자주식회사 | Method for calculating location information and an electronic device thereof |
US10488062B2 (en) | 2016-07-22 | 2019-11-26 | Ademco Inc. | Geofence plus schedule for a building controller |
US10302322B2 (en) | 2016-07-22 | 2019-05-28 | Ademco Inc. | Triage of initial schedule setup for an HVAC controller |
US10306403B2 (en) | 2016-08-03 | 2019-05-28 | Honeywell International Inc. | Location based dynamic geo-fencing system for security |
US9589255B1 (en) | 2016-09-14 | 2017-03-07 | Graffiti Video Inc. | Collaborative media capture and sharing system |
EP3537272A4 (en) * | 2016-11-23 | 2019-11-20 | Huawei Technologies Co., Ltd. | Information processing method, positioning chip, and mobile terminal |
WO2018121862A1 (en) * | 2016-12-29 | 2018-07-05 | Telecom Italia S.P.A. | Method and system for providing a proximity service to a mobile terminal in a smart space |
US11551498B2 (en) | 2018-04-01 | 2023-01-10 | Joseph Hage | Locking system and method for a movable freight container door |
US10713613B2 (en) | 2017-04-03 | 2020-07-14 | Joseph Hage | Redundant wireless electronic motor vehicle chassis monitoring network |
US10317102B2 (en) | 2017-04-18 | 2019-06-11 | Ademco Inc. | Geofencing for thermostatic control |
US10187745B1 (en) | 2017-09-19 | 2019-01-22 | Comcast Cable Communications, Ltd. | System and method for energy efficient geofencing implementation and management |
WO2019078889A1 (en) * | 2017-10-20 | 2019-04-25 | Hewlett-Packard Development Company, L.P. | Device policy enforcement |
US12105206B2 (en) | 2018-04-16 | 2024-10-01 | Pinpoint Ideas, LLC | GPS tracking device with extended battery life |
CN110582054A (en) * | 2018-06-07 | 2019-12-17 | 阿里巴巴集团控股有限公司 | data processing method, device and machine readable medium |
WO2019244543A1 (en) * | 2018-06-22 | 2019-12-26 | ローム株式会社 | Position detection system |
EP3844690A1 (en) * | 2018-08-27 | 2021-07-07 | BASF Corporation | Method and system to digitally track and monitor an automotive refinish repair process |
US11037378B2 (en) | 2019-04-18 | 2021-06-15 | IGEN Networks Corp. | Method and system for creating driver telematic signatures |
US11122424B1 (en) * | 2019-05-14 | 2021-09-14 | Hood Mountain, LLC | Systems, methods and apparatus for data privacy protection based on geofence networks |
CN111031480A (en) * | 2019-11-26 | 2020-04-17 | 武汉虹信技术服务有限责任公司 | Equipment management and area monitoring method based on Bluetooth gateway |
US11482057B2 (en) | 2019-12-14 | 2022-10-25 | SVR Tracking, Inc. | Method and system for battery management for mobile geofencing devices |
CN115334621A (en) * | 2021-05-11 | 2022-11-11 | Oppo广东移动通信有限公司 | Communication event processing method, system, electronic device and storage medium |
KR20230018825A (en) * | 2021-07-30 | 2023-02-07 | 삼성전자주식회사 | An electronic device and method using a geo-fence |
US20230176226A1 (en) * | 2021-12-03 | 2023-06-08 | Here Global B.V. | Offline Radio Maps for Device-Specific GNSS Rescue Areas |
CN117376830B (en) * | 2023-12-04 | 2024-05-07 | 荣耀终端有限公司 | Geofence matching method, electronic device and computer readable storage medium |
Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20080143604A1 (en) * | 2006-12-18 | 2008-06-19 | Motorola, Inc. | Tracking device that conserves power using a sleep mode when proximate to an anchor beacon |
US20090009398A1 (en) * | 2007-07-06 | 2009-01-08 | Qualcomm Incorporated | Tracking implementing geopositioning and local modes |
US20090312032A1 (en) | 2008-06-13 | 2009-12-17 | Qualcomm Incorporated | Optimizing Battery Life and Network Resources During Position Location Tracking Scenario |
Family Cites Families (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
ATE488746T1 (en) | 2002-03-01 | 2010-12-15 | Telecomm Systems Inc | METHOD AND DEVICE FOR SENDING, RECEIVING AND PLANNING LOCATION-RELEVANT INFORMATION |
US8850011B2 (en) | 2005-04-21 | 2014-09-30 | Microsoft Corporation | Obtaining and displaying virtual earth images |
US8593276B2 (en) | 2006-02-01 | 2013-11-26 | Qualcomm Incorporated | Method and apparatus for asset geofencing |
WO2008094685A1 (en) | 2007-02-01 | 2008-08-07 | Global Trek Xploration Corp. | System and method for monitoring the location of a tracking device |
US8018329B2 (en) | 2008-12-12 | 2011-09-13 | Gordon * Howard Associates, Inc. | Automated geo-fence boundary configuration and activation |
US8213957B2 (en) * | 2009-04-22 | 2012-07-03 | Trueposition, Inc. | Network autonomous wireless location system |
-
2011
- 2011-10-13 US US13/272,241 patent/US8810454B2/en active Active
-
2012
- 2012-10-12 CN CN201210388895.1A patent/CN102938927B/en active Active
- 2012-10-12 WO PCT/US2012/060091 patent/WO2013056145A1/en active Application Filing
- 2012-10-12 EP EP12840466.2A patent/EP2767125B1/en active Active
Patent Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20080143604A1 (en) * | 2006-12-18 | 2008-06-19 | Motorola, Inc. | Tracking device that conserves power using a sleep mode when proximate to an anchor beacon |
US20090009398A1 (en) * | 2007-07-06 | 2009-01-08 | Qualcomm Incorporated | Tracking implementing geopositioning and local modes |
US20090312032A1 (en) | 2008-06-13 | 2009-12-17 | Qualcomm Incorporated | Optimizing Battery Life and Network Resources During Position Location Tracking Scenario |
Non-Patent Citations (3)
Title |
---|
BARETH, ENERGY-EFFICIENT POSITION TRACKING IN PROACTIVE LOCATION-BASED SERVICES FOR SMARTPHONE ENVIRONMENT |
KYOUNG, MULTILEVEL LOCATION TRIGGER IN DISTRIBUTED MOBILE ENVIRONMENTS FOR LOCATION-BASED SERVICES |
See also references of EP2767125A4 |
Cited By (36)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US9880604B2 (en) | 2011-04-20 | 2018-01-30 | Microsoft Technology Licensing, Llc | Energy efficient location detection |
EP2595418B1 (en) * | 2011-11-18 | 2019-05-01 | Samsung Electronics Co., Ltd | Method and apparatus for providing an alert on a user equipment entering an alerting area |
EP2790385A1 (en) * | 2013-04-08 | 2014-10-15 | Samsung Electronics Co., Ltd. | Electronic device and method for receiving geo-fence service with low power consumption |
RU2642348C2 (en) * | 2013-06-14 | 2018-01-24 | МАЙКРОСОФТ ТЕКНОЛОДЖИ ЛАЙСЕНСИНГ, ЭлЭлСи | Unification of geozone events |
WO2014200523A1 (en) * | 2013-06-14 | 2014-12-18 | Microsoft Corporation | Coalescing geo-fence events |
US9998866B2 (en) | 2013-06-14 | 2018-06-12 | Microsoft Technology Licensing, Llc | Detecting geo-fence events using varying confidence levels |
US9820231B2 (en) | 2013-06-14 | 2017-11-14 | Microsoft Technology Licensing, Llc | Coalescing geo-fence events |
EP2889578A1 (en) * | 2013-12-30 | 2015-07-01 | 9Solutions Oy | Indoor system for providing navigation data |
CN105611983A (en) * | 2014-03-25 | 2016-05-25 | 华为终端有限公司 | Mail processing method and apparatus |
EP3143814A4 (en) * | 2014-05-16 | 2018-01-24 | Google LLC | Running location provider processes |
EP3063996A4 (en) * | 2014-07-02 | 2017-04-12 | MediaTek Inc. | Mobile communication devices and context-based geofence control methods thereof |
US9712969B2 (en) | 2014-07-02 | 2017-07-18 | Mediatek Inc. | Mobile communication devices and context-based geofence control methods thereof |
EP3225072A4 (en) * | 2014-11-26 | 2018-06-27 | Intel Corporation | Virtual sensor apparatus and method |
WO2016085605A1 (en) | 2014-11-26 | 2016-06-02 | Intel Corporation | Virtual sensor apparatus and method |
EP3041275A1 (en) * | 2015-01-05 | 2016-07-06 | SK Planet Co., Ltd. | Apparatus and method for activating wireless communication function automatically for geo-fence, system comprising the same and non-transitory computer readable storage medium having computer program recorded thereon |
CN105764027B (en) * | 2015-01-05 | 2020-03-20 | Sk 普兰尼特有限公司 | Automatic activation device for wireless communication function of geo-fencing, method thereof and system comprising same |
CN105764027A (en) * | 2015-01-05 | 2016-07-13 | Sk普兰尼特有限公司 | Automatic Activating Device And Method Used For Wireless Communication Function Of Geo-fence And System Comprising Same |
KR102427822B1 (en) * | 2015-08-12 | 2022-08-01 | 삼성전자주식회사 | Method and apparatus for providing location information |
KR20170019806A (en) * | 2015-08-12 | 2017-02-22 | 삼성전자주식회사 | Method and apparatus for providing location information |
USRE48698E1 (en) | 2015-08-12 | 2021-08-17 | Samsung Electronics Co., Ltd. | Method and apparatus for providing location information |
EP3131317A1 (en) * | 2015-08-12 | 2017-02-15 | Samsung Electronics Co., Ltd. | Method and apparatus for providing location information |
US10149095B2 (en) | 2015-08-12 | 2018-12-04 | Samsung Electronics Co., Ltd. | Method and apparatus for providing location information |
WO2018080588A1 (en) * | 2016-10-31 | 2018-05-03 | Intuit Inc. | Battery efficient automatic mileage tracking |
US10502839B2 (en) | 2016-10-31 | 2019-12-10 | Intuit Inc. | Battery efficient automatic mileage tracking |
WO2018118211A3 (en) * | 2016-12-21 | 2018-08-02 | Tile, Inc. | Safe zones in tracking device environments |
US9922531B1 (en) | 2016-12-21 | 2018-03-20 | Tile, Inc. | Safe zones in tracking device environments |
US10176699B2 (en) | 2016-12-21 | 2019-01-08 | Tile, Inc. | Safe zones in tracking device environments |
US10643453B2 (en) | 2016-12-21 | 2020-05-05 | Tile, Inc. | Safe zones in tracking device environments |
US10991229B2 (en) | 2016-12-21 | 2021-04-27 | Tile, Inc. | Safe zones in tracking device environments |
US11984012B2 (en) | 2016-12-21 | 2024-05-14 | Tile, Inc. | Safe zones in tracking device environments |
US11423763B2 (en) | 2016-12-21 | 2022-08-23 | Tile, Inc. | Safe zones in tracking device environments |
US11676475B2 (en) | 2016-12-21 | 2023-06-13 | Tile, Inc. | Safe zones in tracking device environments |
US10325478B2 (en) | 2016-12-21 | 2019-06-18 | Tile, Inc. | Safe zones in tracking device environments |
CN108882207A (en) * | 2017-05-08 | 2018-11-23 | 阿里巴巴集团控股有限公司 | The implementation method and device of near field Trigger Function |
FR3126173A1 (en) * | 2021-08-12 | 2023-02-17 | Follower Products | Method for tracking a goods journey |
WO2023049905A1 (en) * | 2021-09-24 | 2023-03-30 | Accretive Media LLC | Automated measurement and analytics software for out of home content delivery |
Also Published As
Publication number | Publication date |
---|---|
EP2767125B1 (en) | 2016-07-27 |
EP2767125A4 (en) | 2014-08-20 |
CN102938927B (en) | 2015-09-02 |
EP2767125A1 (en) | 2014-08-20 |
US20130093627A1 (en) | 2013-04-18 |
CN102938927A (en) | 2013-02-20 |
US8810454B2 (en) | 2014-08-19 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US8810454B2 (en) | Power-aware tiered geofencing and beacon watchlists | |
GB2531206B (en) | Mobile network based geofencing | |
US8325088B2 (en) | Mobile device battery management | |
US10064003B2 (en) | Beacon-based geofencing | |
EP3008928B1 (en) | Coalescing geo-fence events | |
US20150141045A1 (en) | Geofence | |
JP6479847B2 (en) | Reduction of overlapping geofences | |
US8369837B2 (en) | Task management based on travel distance | |
US9398406B2 (en) | Location-based service provision method and system of electronic device | |
US20120098705A1 (en) | Use of heuristic data for sending message from mobile computing device | |
US11323844B2 (en) | Systems and method for intelligently detecting proximity to locations of interest | |
KR20130055509A (en) | Method and apparatus for providing an alert on a user equipment entering an alerting area |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
121 | Ep: the epo has been informed by wipo that ep was designated in this application |
Ref document number: 12840466 Country of ref document: EP Kind code of ref document: A1 |
|
REEP | Request for entry into the european phase |
Ref document number: 2012840466 Country of ref document: EP |
|
WWE | Wipo information: entry into national phase |
Ref document number: 2012840466 Country of ref document: EP |
|
NENP | Non-entry into the national phase |
Ref country code: DE |