System and method for scheduling location measurements

Information

  • Patent Grant
  • 9510152
  • Patent Number
    9,510,152
  • Date Filed
    Friday, April 11, 2014
    10 years ago
  • Date Issued
    Tuesday, November 29, 2016
    8 years ago
Abstract
System and method for determining when to initiate radio signal measurements to determine mobile device location. The method includes determining a plurality of locations of one or more mobile devices based on radio signal measurements. Acceleration of the one or more mobile devices between the plurality of locations is determined based on sensor measurements. A first location of a particular mobile device is determined and acceleration is measured by the particular mobile device. It is determined when to initiate radio signal measurements by the particular mobile device to determine a second location of the particular mobile device based on the measured acceleration of the particular mobile device, the determined plurality of locations of the one or more mobile devices, and the determined acceleration of the one or more mobile devices. Radio signal measurements are initiated by the particular mobile device to determine the second location of the particular mobile device.
Description
BACKGROUND

Mobile communication devices such as smart phones generally include Global Positioning System (GPS) hardware and other systems for determining device location. Location requests from an application on a mobile communication device may require significant electric power from a location determining system on the device decreasing battery life and affecting the device usability. It would be desirable to minimize a number of location requests by an application to conserve device resources and battery power. However, less frequent location requests may have an undesirable effect on the user experience by requiring an application to use location data too old to provide proper functionality.


SUMMARY

This Summary introduces simplified concepts that are further described below in the Detailed Description of Illustrative Embodiments. This Summary is not intended to identify key features or essential features of the claimed subject matter and is not intended to be used to limit the scope of the claimed subject matter.


Described are a system and methods for minimizing location requests on a mobile device such as GPS location requests. Location requests are minimized by predicting based on acceleration measurements when the device has moved sufficient distance to require a location measurement. If sufficient movement has not been predicted no location request is made to a mobile device's location determining system, thereby minimizing location requests.


A method is provided for determining when to initiate radio signal measurements to determine mobile device location. The method includes determining a plurality of locations of one or more mobile devices based on radio signal measurements. Acceleration of the one or more mobile devices between the plurality of locations is determined based on sensor measurements. A first location of a particular mobile device is determined and acceleration is measured by the particular mobile device. It is determined when to initiate radio signal measurements by the particular mobile device to determine a second location of the particular mobile device based on the measured acceleration of the particular mobile device, the determined plurality of locations of the one or more mobile devices, and the determined acceleration of the one or more mobile devices. Radio signal measurements are initiated by the particular mobile device to determine the second location of the particular mobile device.


Another method for determining when to initiate radio signal measurements to determine mobile device location is provided. The method includes determining a first location of a mobile device, measuring acceleration by the mobile device, and determining when to initiate radio signal measurements by the mobile device to determine a second location of the mobile device based at least on the measured acceleration of the mobile device. Radio signal measurements are initiated by the mobile device to determine the second location of the particular mobile device.


A mobile device is provided comprising at least one non-transitory computer readable storage medium having encoded thereon instructions that, when executed by one or more processors of the device, cause the device to perform a process comprising determining a first location of the mobile device and measuring acceleration by the mobile device. The process further includes determining when to initiate radio signal measurements by the mobile device to determine a second location of the mobile device based at least on the measured acceleration of the mobile device, and initiating radio signal measurements by the mobile device to determine the second location of the mobile device.





BRIEF DESCRIPTION OF THE DRAWING(S)

A more detailed understanding may be had from the following description, given by way of example with the accompanying drawings. The Figures in the drawings and the detailed description are examples. The Figures and the detailed description are not to be considered limiting and other examples are possible. Like reference numerals in the Figures indicate like elements wherein:



FIG. 1 is a diagram showing a system for training and applying motion classifiers to reduce location measurements by a mobile communication device.



FIG. 2 is a flowchart showing a method for training a motion classifier.



FIG. 3 is a process diagram showing inputs to and output from a motion classifier training engine.



FIG. 4 is a process diagram showing inputs to and output from a motion classifier.



FIG. 5 is a flowchart showing a method of implementing a motion classifier to minimize location requests





DETAILED DESCRIPTION OF ILLUSTRATIVE EMBODIMENT(S)

Embodiments of the invention are described below with reference to the drawing figures wherein like numerals represent like elements throughout.


Referring to FIG. 1, a system 10 is provided including a classifier manager 20 configured to aggregate and process data from mobile devices 12 to train classifiers used in predicting mobile device travel. The classifier manager 20 can function in a communications network 40, including one or more computer networks such as the Internet, phone networks, or other wired or wireless networks. The classifier manager 20 and its constituent elements are preferably implemented on one or more network connectable processor-enabled computing systems via hardware components, software components sharing one or more processing units, or a combination hardware and software components. The classifier manager 20 need not be implemented on a single system at a single location, but can be decentralized for example in a peer-to-peer configuration operating on two or more of the mobile communication devices 12 (“mobile devices 12”).


The mobile devices 12 can include for example a smartphone or other cellular enabled mobile device preferably configured to operate on a wireless telecommunication network via suitable hardware and software components. In addition to components enabling wireless communication, the mobile device 12 has one or more location determination systems (LDS) 15, including for example global positioning system (GPS) hardware or hardware used for cell tower triangulation, such that accurate location of the mobile device 12 can be derived. An accelerometer 17 is provided from which a monitoring/control agent 13 (“control agent 13”) gathers data used for predicting distance traveled by the mobile device 12. The mobile device 12 can include additional sensors such as a proximity sensor, luxmeter, magnetometer, and gyroscope.


The classifier manager 20 enables a control application program interface (“API”) 24, a classifier database 26, a training engine 34, a mapping database 36, and a user database 38. The classifier manager 20 can be implemented on one or more network connectable computing systems in communication via the communications network 40 with mobile devices 12 which execute the control agent 13. Alternatively, the classifier manager 20 or one or more components thereof can be executed on a mobile device 12 or other system or a plurality of systems.


Software and/or hardware residing on a mobile device 12 enables the control agent 13 to control requests for location to the LDS 15 from an application or system based at least on acceleration data from the accelerometer 17. The control agent 13 can take as input accelerometer readings from the accelerometer 17 and derive velocity over a particular time interval, for example 1 second, through application of a motion classifier 50. If an earlier determined location from the LDS 15 exists, and if between the time corresponding to that location determination and a current time it is determined through periodic motion classification assessments by applying the mobile device motion classifier 50 that the net movement of the mobile device 12 is small enough, then it is not necessary to make a subsequent location request, and the earlier determined location is considered still valid. If the determined net movement exceeds a particular threshold a new location request to the LDS 15 is triggered. Classifying acceleration measurements can be used in conjunction with other such methods, for example detecting changes in what wireless base stations are closest to the mobile device 12, which may be indicative of a substantive change in location, to determine if a location request is required.


A motion classifier classification result denotes an approximate velocity of the mobile device 12 at the time period over which readings from the accelerometer 17 were gathered. This result can be an approximation of the actual velocity, for example 0 miles/hour (stationary), 7 miles/hour, or 34 miles/hour. The classification result can also include a confidence level, reflecting the accuracy of the result. Alternatively, the classification result can specify a range say 0-5 miles/hour or 10-20 miles/hour, wherein there is a supposition that there is a high likelihood that the directed velocity is within the range of the result.


A motion classifier 50 can be trained by the classifier manager 20 via the training engine 34. Data for training the motion classifier 50 can be received from a mobile device 12 through the control API 24 via the control agent 13 or other suitable source. Alternatively, the motion classifier 50 can be trained by the control agent 13 on the mobile device 12.


Referring to FIG. 2, a method 100 for training a classifier is described. In a step 102 data is retrieved including geographic location measurements and accelerometer measurements corresponding to a mobile device 12 from the accelerometer 17. The accelerometer measurements are partitioned into time intervals (“accelerometer time intervals”) and a location measurement corresponds to each partition, for example at the beginning of adjacent partitions. The distance between measured geographic locations of adjacent partitions are determined (step 104), and the average velocity between each geographic location is determined by dividing the distance between geographic locations of adjacent partitions by the corresponding accelerometer interval between the geographic locations (step 106). The determined distance can be a straight line distance or a distance following a path for example based on map data stored in the map database 36. Each acceleration measurement is associated with the determined average velocity corresponding to its accelerometer time interval (108). The collection of accelerometer readings and associated velocities are saved to a file or set of files and a motion classifier is trained on the files containing the accelerometer reading partitions and their associated velocities (step 110). As indicated above, the training of the motion classifier can be performed by a network connectable computing system remote from the mobile device 12 where the data is collected, or locally by a processor on the mobile device 12.


An example motion classifier includes a decision tree trained on a vertical mean, vertical standard deviation, horizontal mean, or horizontal standard deviation derived from the accelerometer readings. A Hidden Markov Model (“HMM”) can be used to post-process the decision tree output, to increase the predictive validity of the motion classifier classification results.


Measured geographic locations (e.g., GPS determined locations) can be used to condition classifier results. For example, if a large number of GPS samples correspond to substantially the same particular geographic location over a period of time, and it is the case that actual velocity at the particular geographic location (e.g., an office building) is typically slow, then classifier results can be conditioned to correspond to a decreased likelihood that motion has occurred.


Map data from the mapping database 36 or the mobile device 12 used in training can also be used to condition the results of a classifier 50. For example, if the GPS readings used in the training data for the classifier are correlated with map data, it can be determined that a GPS reading corresponds to a location on a road, which can bias classifier results to be more likely that the GPS location has changed, or it can be determined that a GPS reading corresponds to a shopping mall, which can bias classifier results to be less likely that GPS location has changed. Road history can be maintained in the mapping database 36 with respect to traffic conditions occurring at time of day, day of week, or day of year to further condition the likelihood of the degree of relative motion that has occurred. The increased accuracy of classifier predictions due to the consideration of the map and date/time data are incorporated into the resulting classifier model.


Referring to FIG. 3, a classifier training or retraining process diagram 400 showing example inputs to and output from the training engine 34 is shown. A plurality of tuples are received from one or more mobile devices 12. A tuple 210 received from a mobile device 12 via the control agent 13 includes a partition of acceleration measurements 314, location measurement 316, time stamp 318, device descriptor 320 such as device model number and serial number, mobile device operating system descriptor 322, and mobile device settings information 324, which data are input into the classifier training engine 34. Further, map data 230 gathered from the map database 36 or alternatively from the mobile device 12 via the map database 21 can be input to the training engine 34 to account for geographic features in generating results. The training engine 34 outputs a trained or retrained motion classifier 50.


The control agent 13 can download a trained classifier 50 from the classifier manager 20 via the control API 24 and install the classifier 50 on the mobile device 12. Referring to FIG. 5, a method 400 of implementing the motion classifier 50 to minimize location requests is shown, for example GPS location requests from an application (“app”) 19 executed on the mobile device 12. The method 400 is described as performed on the mobile device 12 by the control agent 13 via one or more processing units for a period of time during which location of the mobile device 12 is required. Alternatively, one or more steps of the method 400 can be performed remote from the mobile device 12, for example on a network connectable computing system implementing the classifier manager 20 or other suitable system.


In a step 402, a variable representing a predicted distance traveled between location measurements (“locates”) is set to zero (0). In a step 404 a locate is performed by the LDS 15 (e.g., a GPS locate), for example at the direction of the control agent 13 responsive to a requirement of an app 19. In a step 406, at a particular fixed interval of time (“sample time interval”) for example five (5) minutes, a partition of accelerometer measurements is collected over another particular time interval (“accelerometer time interval”), for example one (1) minute. Alternatively, accelerometer measurements can be collected substantially continuously such that the partition of accelerometer measurements extends the duration of the sample time interval. The partition of accelerometer measurements is fed into the motion classifier 50 by the control agent 13 which produces a result defining a predicted velocity of the mobile device over the accelerometer time interval. In the case where the accelerometer time interval and the sample time interval follow sequentially in series (i.e., the accelerometer time interval starts when the sample time interval ends), in the step 410 the predicted velocity is multiplied by the sum of the accelerometer time interval and the sample time interval to determine a predicted distance traveled over the intervals, and this determined predicted distance is added to the total predicted distance determined subsequent to any zeroing occurring in step 402 to determine the total predicted distance since the last locate. Alternatively, if the sample time interval and the acceleration time interval run at the same time in parallel (i.e., the sample time interval restarts when a new acceleration time interval begins), the predicted velocity is multiplied by the sample time interval to determine the predicted distance traveled over the sample time interval, and this determined predicted distance is added to the total predicted distance determined subsequent to any zeroing occurring in step 402 to determine the total predicted distance since the last locate. As indicated above, map and date/time data are used to condition classifier results and development of the classifier model. Accordingly, in addition to acceleration, the velocity predicted by the classifier 50 and the resulting determined distance traveled can be further based on the location of the mobile device 12 with respect to roads or other geographic features, the time of day, day of week, or day of year.



FIG. 4 shows a classifier process diagram 400 showing example inputs to and output from the classifier 50 corresponding to step 408 of the method 200. Acceleration measurements 314, time stamp 318, device descriptor 320 such as device model number and serial number, mobile device operating system descriptor 322, and mobile device settings information 324 are input into the classifier 50. Further, recent mobile device location measurements 316 and corresponding map data 330 from the map database 21 can be input if the classifier 50 is trained to account for geographic features in generating results. The classifier 50 outputs velocity data 340 used in determining a predicted distance.


It is determined in step 412 whether the total predicted distance exceeds a particular threshold (“Distance Traveled Threshold”). If the particular threshold is not exceeded the process returns to step 406 to collect an additional partition of acceleration measurements and calculate a new total predicted distance. When it is determined in step 412 that the total predicted distance determined in step 410 exceeds the particular threshold, a new location request to the LDS 15 is executed (step 414) producing a new measured location (e.g., a GPS locate).


Further, a distance (“measured distance”) between the new measured location and the immediately prior measured location is determined (step 416). It is determined if the difference between the predicted distance and the measured distance (“DistΔ”) exceeds a particular threshold (“DistΔ Threshold”). If so, the classifier is retrained based on the input data to the classifier 50 (step 420). For example, if the motion classifier 50 is a decision tree classifier, the decision nodes on the tree can be modified to account for the new data. In step 422 the predicted distance is set to zero (0), and then the process returns to step 406 where an additional partition of acceleration measurements is collected after the end of the current sample time interval, which measurements are used to determine new velocity and distance predictions, as described above.


Retraining of a classifier can be performed by the classifier manager 20 via the training engine 34 or by the control agent 13. Retraining can occur on the mobile device 12, or the mobile device can download a new classifier, which has been trained outside of the phone on a training server, for example a server executing the classifier manager 20 with the training engine 34. Optionally, accelerometer data that is tagged with velocity, which has been collected by the mobile device 12, can be sent to a training server, where a classifier model created on the training server can incorporate this new data. If map and date/time data are used in training of the classifier, such inputs can be used in the classifier retraining process insofar as they improve the accuracy of the resulting model.


Further responsive to the difference between the predicted distance and the measured distance (“DistΔ”) exceeding the DistΔ Threshold, the Distance Traveled Threshold can be decreased by a particular value, say 1-10%, causing more frequent location measurements thus improving ground truth validation and the motion classifier 50 retraining process. Alternatively, if the DistΔ is below a particular threshold, the DistΔ Threshold can be increased by a particular value, say 1-10%, resulting in less frequent location measurements and a conservation of power and processing resources on the mobile device 12.


Although features and elements are described above in particular combinations, one of ordinary skill in the art will appreciate that each feature or element can be used alone or in any combination with the other features and elements. Methods described herein may be implemented in a computer program, software, or firmware incorporated in a computer-readable medium for execution by a computer or processor.


While embodiments have been described in detail above, these embodiments are non-limiting and should be considered as merely exemplary. Modifications and extensions may be developed, and all such modifications are deemed to be within the scope defined by the appended claims.

Claims
  • 1. A method for initiating radio signal measurements to determine mobile device location, the method comprising: determining a plurality of locations of at least one mobile device based on radio signal measurements initiated during a first time period;determining acceleration of the at least one mobile device at least between the plurality of locations based on sensor measurements performed during the first time period;determining at least one time interval between the plurality of locations of the at least one mobile device based on time stamps corresponding to the radio signal measurements initiated during the first time period;initiating radio signal measurements by a particular mobile device during a second time period;determining a first location of the particular mobile device based on the radio signal measurements by the particular mobile device initiated during the second time period;measuring acceleration by the particular mobile device during the second time period;determining when to initiate radio signal measurements by the particular mobile device to determine a second location of the particular mobile device based at least on the measured acceleration of the particular mobile device during the second time period, the determined plurality of locations of the at least one mobile device based on measurements initiated during the first time period, the at least one time interval between the plurality of locations of the at least one mobile device, and the determined acceleration of the at least one mobile device based on the sensor measurements performed during the first time period; andinitiating radio signal measurements by the particular mobile device during the second time period to determine the second location of the particular mobile device.
  • 2. The method of claim 1, wherein the radio signal measurements comprise global positioning system (GPS) measurements.
  • 3. The method of claim 1, wherein the at least one mobile device comprises a first mobile device, and the particular mobile device comprises a second mobile device.
  • 4. The method of claim 1, wherein the at least one mobile device comprises the particular mobile device.
  • 5. The method of claim 1, further comprising: training a classifier based at least on the plurality of locations, the at least one time interval, and the determined acceleration of the at least one mobile device; andapplying the classifier to the acceleration measured by the particular mobile device to determine when to initiate radio signal measurements to determine the second location of the particular mobile device.
  • 6. The method of claim 5, further comprising: determining at least one distance between the plurality of locations of the at least one mobile device; andtraining the classifier further based on the at least one distance between the plurality of locations.
  • 7. The method of claim 5, further comprising: determining at least one time interval between the plurality of locations of the at least one mobile device; andtraining the classifier further based on the at least one time interval.
  • 8. The method of claim 5, further comprising training the classifier further based on at least one of a time of the day, a day of the week, or a date of the year corresponding to at least one of the plurality of locations.
  • 9. The method of claim 1, further comprising: determining at least one distance between the plurality of locations of the at least one mobile device;determining at least one velocity between the plurality of locations of the at least one mobile device based on the at least one time interval and the at least one distance; anddetermining when to initiate radio signal measurements by the particular mobile device further based on the at least one velocity between the plurality of locations of the at least one mobile device.
  • 10. The method of claim 1, further comprising: comparing the first location of the particular mobile device with a map of a geographic area comprising geographic features; anddetermining when to initiate the radio signal measurements further based on the location of the particular mobile device with respect to at least one geographic feature of the geographic area.
  • 11. The method of claim 10, wherein the at least one geographic feature comprises a road, wherein it is determined when to initiate the radio signal measurements to determine the second location of the particular mobile device further based on the particular mobile device being on the road.
  • 12. The method of claim 1, further comprising: training a classifier based at least on the plurality of locations, the at least one time interval, and the determined acceleration of the at least one mobile device;applying the classifier to the acceleration measured by the particular mobile device to predict at least one of a velocity of or distance traveled by the particular mobile device; anddetermining when to initiate the radio signal measurements by the particular mobile device based at least on the at least one of the predicted velocity of or predicted distance traveled by the particular mobile device to determine the second location of the particular mobile device.
  • 13. The method of claim 1, further comprising: detecting a change in location of at least one wireless base station relative to the particular mobile device; anddetermining when to initiate radio signal measurements by the particular mobile device to determine a second location further based on the detected change in location of the at least one wireless base station relative to the particular mobile device.
  • 14. The method of claim 1, further comprising: receiving a first device descriptor corresponding to the at least one mobile device;receiving a second device descriptor corresponding to the particular mobile device; anddetermining when to initiate the radio signal measurements further based on first device descriptor and the second device descriptor.
  • 15. The method of claim 1, further comprising: receiving first device setting information corresponding to the at least one mobile device;receiving second device setting information corresponding to the particular mobile device; anddetermining when ID initiate the radio signal measurements further based on the first device setting information and the second device setting information.
  • 16. A method for initiating radio signal measurements to determine mobile device location, the method comprising: determining a plurality of locations of at least one mobile device based on radio signal measurements;determining acceleration of the at least one mobile device at least between the plurality of locations based on sensor measurements;training a classifier by a network-connectable computing system based on data received from the at least one mobile device, the data comprising the determined plurality of locations and the determined acceleration of the at least one mobile device;transmitting the classifier to the particular mobile device; anddetermining a first location of a particular mobile device;measuring acceleration by the particular mobile device;applying the classifier by the particular mobile device by at least one processor to the acceleration measured by the particular mobile device to determine when to initiate radio signal measurements to determine the second location of the particular mobile device; andinitiating radio signal measurements by the particular mobile device to determine the second location of the particular mobile device.
  • 17. A method for initiating radio signal measurements to determine mobile device location, the method comprising: determining a plurality of locations of at least one mobile device based on radio signal measurements;comparing at least one of the plurality of locations with a map of a geographic area comprising geographic features;determining acceleration, of the at least one mobile device at least between the plurality of locations based on sensor measurements;training a classifier based at least on the plurality of locations, the determined acceleration of the at least one mobile device, and the comparison;determining a first location of a particular mobile device;measuring acceleration by the particular mobile device;applying the classifier to the acceleration measured by the particular mobile device to determine when to initiate radio signal measurements to determine the second location of the particular mobile device; andinitiating radio signal measurements by the particular mobile device to determine the second location of the particular mobile device.
  • 18. A method for initiating radio signal measurements to determine mobile device location, the method comprising: determining a plurality of locations of at least one mobile device based on radio signal measurements;determining acceleration of the at least one mobile device at least between the plurality of locations based on sensor measurements;determining a first location of a particular mobile device;comparing the first location of the particular mobile device with a map of a geographic area comprising geographic features;predicting a level of vehicle traffic on the road for a current time;measuring acceleration by the particular mobile device;determining when to initiate radio signal measurements by the particular mobile device to determine a second location of the particular mobile device based at least on the measured acceleration of the particular mobile device, the determined plurality of locations of the at least one mobile device, the determined acceleration of the at least one mobile device, the location of the particular mobile device with respect to at least one geographic feature of the geographic area, the at least one geographic feature comprising a road, and based on the particular mobile device being on the road and the predicted level of vehicle traffic on the road; andinitiating radio signal measurements by the particular mobile device to determine the second location of the particular mobile device.
  • 19. A method for initiating radio signal measurements to determine mobile device location, the method comprising: determining a plurality of locations of at least one mobile device based on radio signal measurement;determining acceleration of the at least one mobile device at least between the plurality of locations based on sensor measurements;determining a first location of a particular mobile device;measuring acceleration by the particular mobile device;predicting a velocity of the particular mobile device based at least on the acceleration of the particular mobile device, the determined plurality of locations of the at least one mobile device, and the determined acceleration of the at least one mobile device; anddetermining when to initiate radio signal measurements by the particular mobile device to determine a second location of the particular mobile device based at least on the predicted velocity of the particular mobile device; andinitiating radio signal measurements by the particular mobile device to determine the second location of the particular mobile device.
  • 20. The method of claim 19, further comprising: determining a confidence level of the predicted velocity; anddetermining when to initiate radio signal measurements by the particular mobile device further based at least on the determined confidence level.
  • 21. The method of claim 19, further comprising: predicting a distance traveled by the particular mobile device based on the predicted velocity; anddetermining when to initiate radio signal measurements by the particular mobile device further based on the predicted distance traveled by the particular mobile device.
  • 22. The method of claim 21, further comprising initiating radio signal measurements by the particular mobile device to determine a second location of the particular mobile device responsive to the predicted distance exceeding a particular threshold.
  • 23. A method for initiating radio signal measurements to determine mobile device location, the method comprising: determining a plurality of locations of at least one mobile device based on radio signal measurements;determining acceleration of the at least one mobile device at least between the plurality of locations based on sensor measurements;training a classifier based at least on the plurality of locations and the determined acceleration of the at least one mobile device;determining a first location of a particular mobile device;measuring acceleration by the particular mobile device;applying the classifier to the acceleration measured by the particular mobile device to predict at least one of a velocity of or distance traveled by the particular mobile device;determining when to initiate radio signal measurements by the particular mobile device to determine a second location of the particular mobile device based at least on the at least one of the predicted velocity of or predicted distance traveled by the particular mobile device to determine the second location of the particular mobile device;initiating radio signal measurements by the particular mobile device to determine the second location of the particular mobile device;determining a distance traveled by the particular mobile device based on the first location and the second location of the particular mobile device;comparing the determined distance traveled by the particular mobile device with the predicted distance traveled by the particular mobile device; andretraining the classifier based at least on the comparison of the determined distance and the predicted distance.
  • 24. The method of claim 23, wherein retraining the classifier comprises adjusting a velocity result of the classifier based at least on the determined distance.
  • 25. The method of claim 23, wherein the classifier is retrained further based on at least one of a geographic feature, a time of the day, a day of the week, or a date of the year corresponding to at least one of the first location or the second location of the particular mobile device.
  • 26. A method for initiating radio signal measurements to determine mobile device location, the method comprising: determining a plurality of locations of at least one mobile device based on radio signal measurements;determining acceleration of the at least one mobile device at least between the plurality of locations based on sensor measurements;training a classifier based at least on the plurality of locations and the determined acceleration of the at least one mobile device;determining a first location of a particular mobile device;measuring acceleration the particular mobile device;applying the classifier to the acceleration measured by the particular mobile device to predict at least one of a velocity of or distance traveled by the particular mobile device;determining when to initiate radio signal measurements by the particular mobile device to determine a second location of the particular mobile device based on the predicted distance exceeding a predetermined threshold;initiating radio signal measurements by the particular mobile device to determine the second location of the particular mobile device.
  • 27. The method of claim 26, further comprising: determining a distance traveled by the particular mobile device based on the first location and the second location of the particular mobile device;comparing the determined distance traveled by the particular mobile device with the predicted distance traveled by the particular mobile device; andadjusting the predetermined threshold based on the comparison of the determined distance and the predicted distance.
  • 28. The method of claim 26, further comprising measuring additional acceleration by the particular mobile device;applying the classifier to the additional acceleration measured by the particular mobile device to predict an additional distance traveled by the particular mobile device;determining to initiate additional radio signal measurements by the particular mobile device further based on the predicted additional distance traveled by the particular mobile device exceeding the adjusted threshold; andinitiating the additional radio signal measurements by the particular mobile device to determine a third location of the particular mobile device.
  • 29. A method for initiating radio signal measurements to determine mobile device location, the method comprising: initiating radio signal measurements by a mobile device during a first time period and determining a plurality of locations of the mobile device based on the radio signal measurements initiated during the first time period;determining at least one time interval between the plurality of locations of the mobile device based on the radio signal measurements initiated during the first time period;performing acceleration measurements by the mobile device during the first time period and determining acceleration of the mobile device at least between the plurality of locations based on the acceleration measurements performed during the first time period;initiating radio signal measurements by the mobile device during a second time period and determining a first location of the mobile device corresponding to the second time period based on the radio signal measurements initiated during the second time period;performing acceleration measurements by the mobile device during the second time period and determining acceleration of the mobile device based on the acceleration measurements by the mobile device performed during the second time period;determining when to initiate radio signal measurements by the particular mobile device to determine a second location of the particular mobile device based at least on the measured acceleration during the second time period, the determined plurality of locations during the first time period, the at least one time interval between the plurality of locations during the first time period, and the determined acceleration during the first time period; andinitiating radio signal measurements by the particular mobile device to determine the second location of the particular mobile device.
  • 30. The method of claim 29, further comprising providing an application to the mobile device, the application via one or more processors of the mobile device enabling: the determining of when to initiate the radio signal measurements;the initiating of the radio signal measurements; andthe performing of the acceleration measurements.
  • 31. The method of claim 29, initiating the radio signal measurements comprising initiating GPS location requests via GPS hardware on the mobile device.
  • 32. The method of claim 29, further comprising performing the acceleration measurements via an accelerometer on the mobile device.
  • 33. The method of claim 29, further comprising: comparing at least one of the plurality of locations with a map of a geographic area comprising geographic features; anddetermining when to initiate radio signal measurements by the particular mobile device to determine a second location further based on the comparison.
  • 34. The method of claim 29, further comprising: comparing the first location with a map of a geographic area comprising geographic features; anddetermining when to initiate radio signal measurements by the particular mobile device to determine a second location further based on the comparison.
  • 35. The method of claim 29, further comprising: training a classifier based at least on the plurality of locations, the at least one time interval, and the acceleration measured by the mobile device during the first time period; andapplying the classifier to the acceleration measured by the mobile device during the second time period to determine when to initiate radio signal measurements to determine the second location of the particular mobile device.
  • 36. The method of claim 35, further comprising: comparing at least one of the plurality of locations with a map of a geographic area comprising geographic features; andtraining the classifier further based on the comparison.
  • 37. A mobile device comprising at least one non-transitory computer readable storage medium, at least one processor, an acceleration sensor, and radio signal measurement hardware, the computer readable storage medium having encoded thereon instructions that, when executed by the at least one processor of the device, cause the device to perform a process comprising: initiating radio signal measurements during a first time period and determining a plurality of locations of the mobile device based on the radio signal measurements initiated during the first time period;determining at least one time interval between the plurality of locations of the mobile device based on the radio signal measurements initiated during the first time period;performing acceleration measurements by the acceleration sensor during the first time period and determining acceleration of the mobile device at least between the plurality of locations based on the acceleration measurements performed during the first time period;initiating radio signal measurements during a second time period and determining a first location of the mobile device corresponding to the second time period based on the radio signal measurements initiated during the second time period;performing acceleration measurements by the acceleration sensor during the second time period and determining acceleration of the mobile device based on the acceleration measurements by the mobile device performed during the second time period;determining when to initiate radio signal measurements to determine a second location of the particular mobile device based at least on the measured acceleration during the second time period, the determined plurality of locations during the first time period, the at least one time interval between the plurality of locations during the first time period, and the determined acceleration during the first time period; andinitiating radio signal measurements to determine the second location of the particular mobile device.
US Referenced Citations (161)
Number Name Date Kind
5223844 Mansell et al. Jun 1993 A
5278539 Lauterbach et al. Jan 1994 A
5604787 Kotzin et al. Feb 1997 A
5628050 McGraw et al. May 1997 A
5724243 Westerlage et al. Mar 1998 A
5732383 Foladare et al. Mar 1998 A
5815802 Loechner, II Sep 1998 A
5907293 Tognazzini May 1999 A
5948040 Delorme et al. Sep 1999 A
5959577 Fan et al. Sep 1999 A
5959945 Kleiman Sep 1999 A
6031455 Grube et al. Feb 2000 A
6052574 Smith Apr 2000 A
6052598 Agrawal et al. Apr 2000 A
6091956 Hollenberg Jul 2000 A
6115611 Kimoto et al. Sep 2000 A
6134454 Foladare et al. Oct 2000 A
6236933 Lang May 2001 B1
6240284 Bugnon et al. May 2001 B1
6256577 Graunke Jul 2001 B1
6278375 Hucker Aug 2001 B1
6351221 Phillips et al. Feb 2002 B1
6381465 Chern et al. Apr 2002 B1
6400956 Richton Jun 2002 B1
6480783 Myr Nov 2002 B1
6501947 Hunzinger et al. Dec 2002 B1
6519465 Stilp et al. Feb 2003 B2
6615130 Myr Sep 2003 B2
6631267 Clarkson et al. Oct 2003 B1
6647257 Owensby Nov 2003 B2
6647269 Hendrey et al. Nov 2003 B2
6690940 Brown et al. Feb 2004 B1
6731238 Johnson May 2004 B2
6731940 Nagendran May 2004 B1
6745021 Stevens Jun 2004 B1
6772213 Glorikian Aug 2004 B2
6795710 Creemer Sep 2004 B1
6834195 Brandenberg et al. Dec 2004 B2
6914525 Rao et al. Jul 2005 B2
6941126 Jordan, Jr. Sep 2005 B1
6947835 Kaplan et al. Sep 2005 B2
7039387 Macolly et al. May 2006 B2
7046962 Belcea May 2006 B1
7054612 Patel May 2006 B2
7096115 Groth et al. Aug 2006 B1
7106843 Gainsboro et al. Sep 2006 B1
7123926 Himmelstein Oct 2006 B2
7184744 Schnabel Feb 2007 B1
7194249 Phillips et al. Mar 2007 B2
7202814 Caspi et al. Apr 2007 B2
7260378 Holland et al. Aug 2007 B2
7301450 Carrino Nov 2007 B2
7313383 Fuji Dec 2007 B2
7463890 Herz et al. Dec 2008 B2
7525484 Dupray et al. Apr 2009 B2
7643834 Ioppe et al. Jan 2010 B2
7653218 Maltz et al. Jan 2010 B1
7688731 Haumont et al. Mar 2010 B2
7705726 Graves et al. Apr 2010 B2
7764946 Sennett et al. Jul 2010 B1
7805131 Cholkar et al. Sep 2010 B2
7813326 Kelm et al. Oct 2010 B1
7864073 Lee et al. Jan 2011 B2
7876704 Bims et al. Jan 2011 B1
7941161 Ioppe et al. May 2011 B2
7941162 Ioppe et al. May 2011 B2
7957355 Helfering et al. Jun 2011 B1
8010102 Glick et al. Aug 2011 B2
8060017 Schlicht et al. Nov 2011 B2
8095175 Todd et al. Jan 2012 B2
8107432 Seo Jan 2012 B2
8200248 Ioppe et al. Jun 2012 B2
8204514 Ioppe et al. Jun 2012 B2
8249627 Olincy et al. Aug 2012 B2
8255393 Yu et al. Aug 2012 B1
8315597 Olincy et al. Nov 2012 B2
8351408 Daigle Jan 2013 B2
8369838 Mallavarapu et al. Feb 2013 B2
8503994 Sanjeev Aug 2013 B1
8594065 Polito et al. Nov 2013 B2
8606302 Ioppe et al. Dec 2013 B2
8725174 Grossman et al. May 2014 B2
8750243 Aghvami et al. Jun 2014 B2
8768286 Naboulsi Jul 2014 B2
20010022558 Karr, Jr. et al. Sep 2001 A1
20010029425 Myr Oct 2001 A1
20010044310 Lincke Nov 2001 A1
20020128768 Nakano et al. Sep 2002 A1
20030016770 Trans et al. Jan 2003 A1
20030078055 Smith et al. Apr 2003 A1
20030086515 Trans et al. May 2003 A1
20030104821 Gerner Jun 2003 A1
20030156543 Sahinoglu et al. Aug 2003 A1
20030216138 Higuchi et al. Nov 2003 A1
20040064565 Batra et al. Apr 2004 A1
20040146007 Saadawi et al. Jul 2004 A1
20050122259 Sairo et al. Jun 2005 A1
20060025158 Leblanc et al. Feb 2006 A1
20060050820 Kawada et al. Mar 2006 A1
20060058036 Watanabe et al. Mar 2006 A1
20060079245 Moed Apr 2006 A1
20060089136 Rajkotia Apr 2006 A1
20060111089 Winter et al. May 2006 A1
20060223494 Chmaytelli et al. Oct 2006 A1
20060253526 Welch et al. Nov 2006 A1
20070072583 Barbeau et al. Mar 2007 A1
20070149214 Walsh et al. Jun 2007 A1
20070189154 Hourtane et al. Aug 2007 A1
20070270132 Poosala Nov 2007 A1
20070293240 Drennan Dec 2007 A1
20080169920 Spencer Jul 2008 A1
20080242373 Lu et al. Oct 2008 A1
20090002147 Bloebaum et al. Jan 2009 A1
20090067324 Licardie et al. Mar 2009 A1
20090156161 Strahs Jun 2009 A1
20090175238 Jetcheva et al. Jul 2009 A1
20090245118 McCormick Oct 2009 A1
20100120429 Kazmi et al. May 2010 A1
20100190513 Andreasson Jul 2010 A1
20100210254 Kelly et al. Aug 2010 A1
20100272268 Sambhwani et al. Oct 2010 A1
20100279626 Bradley et al. Nov 2010 A1
20100285815 Treu et al. Nov 2010 A1
20100291950 Lin et al. Nov 2010 A1
20100323659 Wehling Dec 2010 A1
20110034183 Haag et al. Feb 2011 A1
20110093161 Zhou et al. Apr 2011 A1
20110117878 Barash et al. May 2011 A1
20110151830 Blanda et al. Jun 2011 A1
20110164527 Mishra et al. Jul 2011 A1
20110228753 Polito Sep 2011 A1
20110230201 Hotes et al. Sep 2011 A1
20110250871 Huang et al. Oct 2011 A1
20110257883 Kuznetsov Oct 2011 A1
20110267981 Davies Nov 2011 A1
20110268022 Xu Nov 2011 A1
20110275321 Zhou et al. Nov 2011 A1
20110294520 Zhou et al. Dec 2011 A1
20120001548 Recker et al. Jan 2012 A1
20120009890 Curcio et al. Jan 2012 A1
20120081500 Border et al. Apr 2012 A1
20120083287 Casto et al. Apr 2012 A1
20120100866 Grossman et al. Apr 2012 A1
20120158422 Burnham Jun 2012 A1
20120188163 Xiao Jul 2012 A1
20120223861 Kupfer Sep 2012 A1
20120243460 Muto et al. Sep 2012 A1
20120244883 Tibbits et al. Sep 2012 A1
20120289252 Hotes et al. Nov 2012 A1
20120295622 Kazmi et al. Nov 2012 A1
20120315880 Peitrow et al. Dec 2012 A1
20130084847 Tibbitts et al. Apr 2013 A1
20130158860 Gum Jun 2013 A1
20130211706 Macnaughtan et al. Aug 2013 A1
20130217331 Manente Aug 2013 A1
20130303106 Martin Nov 2013 A1
20130344891 Hotes et al. Dec 2013 A1
20140247126 Grossman et al. Sep 2014 A1
20150065163 Murakami Mar 2015 A1
20150087332 Pijl Mar 2015 A1
20160080909 Grossman et al. Mar 2016 A1
Foreign Referenced Citations (5)
Number Date Country
0781067 Jun 1997 EP
1081974 Mar 2001 EP
WO 2009080105 Jul 2009 IT
11346380 Dec 1999 JP
WO 2010090558 Aug 2010 SE
Non-Patent Literature Citations (2)
Entry
International Search Report dated Nov. 3, 2011 for PCTAU02011001038.
Digital cellular telecommunications system (Phase 2+) (GSM):Universal Mobile Telecommunications System (UMTS); Location Services (LCS); Service description, Stage 1 (3GPP TS 22.871 version 4.3.0 Release 4); ETSI TS 122 071 V4.3.0 (Mar. 2001) ETSI TS 122 071 V4.3.0, XX, XX, Apr. 25, 2001, pp. 1-41, XP002222160.
Related Publications (1)
Number Date Country
20150296343 A1 Oct 2015 US