WO2013056145A1 - Power-aware tiered geofencing and beacon watchlists - Google Patents

Power-aware tiered geofencing and beacon watchlists Download PDF

Info

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
Application number
PCT/US2012/060091
Other languages
French (fr)
Inventor
Stephen James COSMAN
Original Assignee
Microsoft Corporation
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Microsoft Corporation filed Critical Microsoft Corporation
Priority to EP12840466.2A priority Critical patent/EP2767125B1/en
Publication of WO2013056145A1 publication Critical patent/WO2013056145A1/en

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W4/00Services specially adapted for wireless communication networks; Facilities therefor
    • H04W4/02Services making use of location information
    • H04W4/021Services related to particular areas, e.g. point of interest [POI] services, venue services or geofences
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01SRADIO 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/00Satellite radio beacon positioning systems; Determining position, velocity or attitude using signals transmitted by such systems
    • G01S19/01Satellite radio beacon positioning systems transmitting time-stamped messages, e.g. GPS [Global Positioning System], GLONASS [Global Orbiting Navigation Satellite System] or GALILEO
    • G01S19/13Receivers
    • G01S19/34Power consumption
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01SRADIO 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/00Position-fixing by co-ordinating two or more direction or position line determinations; Position-fixing by co-ordinating two or more distance determinations
    • G01S5/01Determining conditions which influence positioning, e.g. radio environment, state of motion or energy consumption
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01SRADIO 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/00Position-fixing by co-ordinating two or more direction or position line determinations; Position-fixing by co-ordinating two or more distance determinations
    • G01S5/01Determining conditions which influence positioning, e.g. radio environment, state of motion or energy consumption
    • G01S5/019Energy consumption
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/52Network services specially adapted for the location of the user terminal
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W64/00Locating users or terminals or network equipment for network management purposes, e.g. mobility management
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01SRADIO 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/00Satellite radio beacon positioning systems; Determining position, velocity or attitude using signals transmitted by such systems
    • G01S19/38Determining a navigation solution using signals transmitted by a satellite radio beacon positioning system
    • G01S19/39Determining 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/42Determining position
    • G01S19/48Determining position by combining or switching between position solutions derived from the satellite radio beacon positioning system and position solutions derived from a further system
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W52/00Power management, e.g. TPC [Transmission Power Control], power saving or power classes
    • H04W52/02Power saving arrangements
    • H04W52/0209Power saving arrangements in terminal devices
    • H04W52/0261Power saving arrangements in terminal devices managing power supply demand, e.g. depending on battery level
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W52/00Power management, e.g. TPC [Transmission Power Control], power saving or power classes
    • H04W52/02Power saving arrangements
    • H04W52/0209Power saving arrangements in terminal devices
    • H04W52/0261Power saving arrangements in terminal devices managing power supply demand, e.g. depending on battery level
    • H04W52/0287Power 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/0293Power 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
    • YGENERAL 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
    • Y02TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
    • Y02DCLIMATE 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/00Reducing energy consumption in communication networks
    • YGENERAL 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
    • Y02TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
    • Y02DCLIMATE 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/00Reducing energy consumption in communication networks
    • Y02D30/70Reducing 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

CLAIMS WHAT IS CLAIMED IS:
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.
PCT/US2012/060091 2011-10-13 2012-10-12 Power-aware tiered geofencing and beacon watchlists WO2013056145A1 (en)

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)

* Cited by examiner, † Cited by third party
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)

* Cited by examiner, † Cited by third party
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)

* Cited by examiner, † Cited by third party
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)

* Cited by examiner, † Cited by third party
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

Patent Citations (3)

* Cited by examiner, † Cited by third party
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)

* Cited by examiner, † Cited by third party
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)

* Cited by examiner, † Cited by third party
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