Method for accelerometer-assisted navigation

Information

  • Patent Grant
  • 11927447
  • Patent Number
    11,927,447
  • Date Filed
    Monday, June 28, 2021
    3 years ago
  • Date Issued
    Tuesday, March 12, 2024
    10 months ago
Abstract
A method for primarily sensor-based navigation includes: in a first time period, collecting geophysical position data using a GPS receiver of a navigation device; in the first time period, collecting a first set of accelerometer data using an accelerometer of the navigation device; analyzing the first set of accelerometer data to produce a first set of vertical vehicular motion data; generating a mapping association between the first set of vertical vehicular motion data and the geophysical position data; in a second time period after the first time period, collecting a second set of accelerometer data using the accelerometer; analyzing the second set of accelerometer data to produce a second set of vertical vehicular motion data; and calculating an estimated location of the vehicle by analyzing the second set of vertical vehicular motion data in light of the mapping association.
Description
TECHNICAL FIELD

This invention relates generally to the vehicle telematics field, and more specifically to a new and useful method for determining accelerometer-assisted navigation in the vehicle telematics field.


BACKGROUND

GPS receivers are now commonly used in vehicles to provide location data—which can be used for vehicle tracking, routing, and a number of other important tasks. In particular, many drivers of personal vehicles take advantage of the GPS receivers commonly found in smartphones to provide location data.


Unfortunately, those GPS receivers are power-hungry, and can rapidly drain precious smartphone battery reserves. To add to this issue, GPS also requires a relatively unoccluded line of sight between the receiver and GPS satellites, which may be problematic in cities and other areas. Given these issues, GPS alone may not provide a satisfactory navigation solution in many scenarios. Thus, there is a need in the vehicle telematic field to create a new and useful method for accelerometer-assisted navigation. This invention provides such a new and useful method.





BRIEF DESCRIPTION OF THE FIGURES


FIG. 1 is a flowchart representation of a method of a preferred embodiment;



FIG. 2 is a flowchart representation of a first implementation of a method of a preferred embodiment;



FIG. 3 is a flowchart representation of a second implementation of a method of a preferred embodiment;



FIGS. 4A, 4B, and 4C are schematic graphical representations of the horizontal velocity dependence of vehicular motion data on position;



FIGS. 5A, 5B, and 5C are schematic graphical representations of the horizontal velocity dependence of vehicular motion data on time;



FIG. 6 is an example representation of matching supplementary data to map data; and



FIG. 7 is a flowchart representation of automatic driver identification of a method of a preferred embodiment.





DESCRIPTION OF THE PREFERRED EMBODIMENTS

The following description of the preferred embodiments of the invention is not intended to limit the invention to these preferred embodiments, but rather to enable any person skilled in the art to make and use this invention.


As shown in FIG. 1, a method 100 for accelerometer-assisted navigation includes collecting GPS data S120, collecting supplementary data S130, associating the GPS data and the supplementary data S140, and performing navigation based on the supplementary data S150. The method 100 may additionally or alternatively include detecting a repeated trip S110.


The method 100 functions to enable navigation using supplementary data (e.g., accelerometer data, barometer data, gyroscope data, compass data, crowdsourced navigation data) as a way to reduce the use of GPS radios, thus saving power and/or allowing navigation in areas not conducive to GPS-based navigation.


As shown in FIG. 2, the method 100 is preferably used to enable primarily accelerometer-based navigation of a commonly traveled route (detected by S110); while driving the route, both GPS data and accelerometer data are taken so that accelerometer data may be associated with the route (S120 and S130). After enough accelerometer data has been collected, the accelerometer data is associated with position data taken by the GPS receiver (S140), thus creating an association between position along the route (and/or motion along the route) and accelerometer data. Once a satisfactory association has been created, the accelerometer data may be used (either alone or in combination with GPS) to perform navigation (S150).


As shown in FIG. 3, the method 100 may also be used to enable primarily barometer-based navigation of a commonly traveled route (detected by S110); similarly to the accelerometer-drive approach, while driving the route, both GPS data and barometer data are taken so that barometer data may be associated with the route (S120 and S130). After enough barometer data has been collected, the barometer data is associated with position data taken by the GPS receiver (S140), thus creating an association between position along the route (and/or motion along the route) and barometer data. Once a satisfactory association has been created, the barometer data may be used (either alone or in combination with GPS) to perform navigation (S150). Barometer data may be particularly interesting as a supplementary data source thanks to relative insensitivity to user movement of the navigation device.


Additionally or alternatively, the method 100 may be used to enable a number of supplementary-data-assisted navigation techniques. For example, the method 100 may be used to reduce the amount of time a GPS radio is active (e.g., measuring GPS data at certain intervals and performing dead reckoning between those intervals using accelerometer data) without explicitly associating position with accelerometer data (in this case, accelerometer data may be linked to a change in position, but not necessarily an absolute position). As another example, the method 100 may use the presence (or lack of presence) of radio transmitters (e.g., cellular, Wi-Fi, etc.) and characteristics of their transmissions to aid in navigation.


While supplementary data preferably includes accelerometer data, supplementary data may include any data suitable for performing navigation; for example, visual data (e.g., images from a camera), audio data (e.g., ambient road noise), and/or altitude data (e.g., as measured by a barometer). Supplementary data may additionally or alternatively include location data received from other sources; for example, GPS data from a nearby GPS receiver (e.g., the GPS receiver of a smartphone in a nearby car) may be used as an approximate indicator of location.


The method 100 is preferably implemented on a smartphone having a GPS receiver and an accelerometer, but may additionally or alternatively be implemented on any electronic device including or in communication with a GPS (or other GNSS-based system) receiver (e.g., smart watches, tablets, head-mounted displays, smart glasses). Hereafter, the device implementing the method 100 shall be referred to as a navigation device.


S110 includes detecting a repeated trip. S110 functions to detect that a navigation device user is traveling along a frequently traveled route (or, alternatively, traveling between a source and a destination frequently chosen together).


S110 preferably aids in determining which routes are ideal for performing supplementary data and GPS data association. For example, for navigation using solely accelerometer data (after accelerometer data has been associated with position) to be robust, the method 100 may require accelerometer data taken across multiple trips (e.g., to average that data or otherwise generate a strong signal from that data). Resultantly, the method 100 in some implementations may not collect supplementary data and/or may not process supplementary data until after detection of a repeated trip (e.g., repeated route, repeated source/destination pair) via S110.


S110 may include storing the number of times a source address or location has been used, the number of times a destination address or location has been used, the number of times a particular source/destination pair is used, and/or any suitable navigation data.


S110 may include detecting a repeated trip by comparing source and/or destination to stored data. Additionally or alternatively, S110 may include detecting a trip in any manner; for example, S110 may include detecting a trip by comparing a traveled route to a portion of a route linked with a repeated trip. In this example, a user may begin driving from home to work; S110 detects that the user is traveling along a route the user typically takes for this trip.


Trip detection may occur with the aid of a user-submitted travel source and/or a user-submitted travel destination; alternatively, trip detection may occur without the aid of a user-submitted travel source and/or travel destination. If trip detection occurs without a user entering a specific travel source, S110 may include turning on a GPS receiver of the navigation device and detecting the travel source location via GPS; however, detecting or estimating a travel source may be accomplished in any suitable manner. If trip detection occurs without a user entering a specific destination, S110 may include prompting the user to select from frequent destinations. For example, if S110 detects a user driving from home to a destination roughly in the direction of both a ‘work’ waypoint and a ‘daycare’ waypoint, S110 may include prompting the user to select from these destinations. If trip detection occurs without a user entering a specific destination, S110 may also include predicting a potential destination based on any suitable navigation data. For example, if S110 detects a user driving in a location close to the user's home address and in the direction of the user's home, S110 may predict that the user is traveling home. In this example, S110 may leverage additional information in predicting a potential destination; for example, if S110 detects that the user is driving at a certain time (e.g., on a weekday in the evening), S110 may become more confident in a prediction that the user is returning home. If trip detection occurs without a user entering a specific destination and S110 includes predicting a potential destination, the predicting step may include performing a historical analysis of user navigation data. The historical analysis functions to aggregate and synthesize user navigation data of different types (e.g., number of times a source address or location has been used, the number of times a destination address or location has been used, the number of times a particular source/destination pair is used, the time of day, the instantaneous direction of user travel, etc.). Preferably, S110 may use the historical analysis to make an informed prediction of a user destination in the absence of explicit user-input, but S110 may additionally or alternatively use the historical analysis for any other suitable purpose. The historical analysis may further include using navigation data from other users; for example, even if the user does not have an extensive user navigation data set, S110 may be able to predict a user destination based on common destinations that other users travel towards (e.g., towards a civic center or stadium).


S110 may include performing trip detection using any suitable data. For example, S110 may include detecting that a user is going to daycare based on the sounds of children's laughter (as sensed by a smartphone microphone) or that a user is going to work based on the time of day (e.g., the time the user normally leaves the house for work). As another example, S110 may include performing repeated trip detection based on user calendar/appointment information; if a user has an electronic calendar linked to the navigation system, the navigation system may identify repeated trip destinations based on information contained therein (e.g., stored destination, company name, contact name, time and date, etc.). As another example, S110 may include performing trip detection based on recent internet searches; if a user has used the internet recently to look up an address or to search for the name of a restaurant, and if the navigation system is linked to the user and also connected to the internet, the navigation system may identify a trip destination based on such a recent search even without a user explicitly indicating a specific intended destination.


In one variation of a preferred embodiment, S110 includes taking user input to determine frequent trips. For example, a user may specify a frequent trip that they take (e.g., home to work) so that accelerometer data collection/processing begins immediately for the route (as opposed to identifying that route automatically as a repeated trip after observing the user taking that route frequently).


In another variation of a preferred embodiment, S110 includes generating a set of previously traveled routes and determining a particular previously traveled route from the set as the detected previously traveled route. Preferably, each previously traveled route is associated with geophysical positions mapped to supplementary data (e.g., accelerometer data, barometer data, audio data, etc.) to enable navigation based, at least in part, on such supplementary data. Generating the previously traveled routes may be determined from any suitable sensor data, GPS data, and/or user navigation data; these data may also be used to compute probability weights (i.e., prediction confidence estimates) associated with each previously traveled route which may assist in determining a particular previously traveled route as the detected previously traveled route. For example, if the set of previously traveled routes includes two routes which are similar but which diverge at a particular geophysical location, vehicular motion data at that particular geophysical location may help S110 to distinguish the two routes; S110 may use this data to update probability weights corresponding to both routes and detect the route with the higher probability. The probability weights may be statically determined (e.g., determined when the user first begins to travel), dynamically updated (e.g., continuously updated based on any suitable data), or otherwise determined. S110 may include any suitable method for generating the set of previously traveled routes and for selecting a particular one of the set as the detected previously traveled route.


In response to detecting a previously traveled route, S110 may further include navigating according to the previously traveled route, which functions to provide travel directions to the user. In response to detecting a previously traveled route with sufficient supplementary data, S110 may further include changing an operating state of the GPS receiver (e.g., changing a duty cycle of the GPS receiver, switching off the GPS receiver, etc.) and navigating based on the supplementary data without collecting additional GPS data. S110 may also include taking any other suitable action in response to detecting a previously traveled route.


S120 includes collecting GPS data. S120 functions to collect navigation data using a GPS receiver; this data may be used to learn new routes and/or as a primary source of position data for navigation purposes. Additionally or alternatively, S120 may include collecting any global navigation satellite system (GNSS) data (e.g., GLONASS, Galileo, BeiDou, etc.).


S120 preferably includes collecting GPS data according to a navigation system operating state. Operating states preferably dictate how GPS data is collected, including data collection frequency, GPS receiver power state, GPS receiver orientation, etc.


S120 preferably functions to collect GPS data when necessary for navigation and/or route learning purposes, while disabling the GPS receiver when GPS data collection is not necessary. For example, S120 may include turning off a GPS receiver if a route is well-known by a supplementary navigation source (e.g., it can be navigated solely by accelerometer data, barometer data, or any other suitable supplementary data). As another example, S120 may include collecting GPS data infrequently (e.g., once every ten seconds) for well-known routes. In contrast, S120 may include collecting GPS data frequently (e.g., a few times a second) for routes that are not known.


S120 may additionally or alternatively include modifying operating states (e.g., switching a GPS receiver off) if the receiver is not able to receive position information (or position information is below a quality threshold). For example, a user traveling through a dense city may not be able to receive a high-quality GPS position data. Such city locations (sometimes referred to as “urban canyons” or “street canyons”) affect the quality of received GPS position data due to both shadowing and multipath interference. Shadowing refers to GPS errors incurred due to line-of-sight effects; in the context of a dense city, tall buildings may physically block the transmission of a GPS signal to a GPS receiver, effectively casting a GPS “shadow” over particular city locations. S120 may include detecting such shadowing effects (e.g., by observing changes in the total received GPS signal power) and then modifying an operating state of the GPS receiver (e.g., switching the GPS receiver off to save battery power, decreasing the duty cycle of the GPS receiver to preserve power until shadowing effects are diminished, etc.). Multipath interference refers to errors incurred to due wave interference; in the context of a dense city, buildings may reflect GPS signals on their way to the GPS receiver, resulting in multiple received signals at the GPS receiver that are recorded to have traveled different distances and farther than the direct line-of-sight distance between GPS satellites and the GPS receiver. Since the direct line-of-sight distance is used to locate the GPS receiver, errors in this quantity result in errors in the determination of the location of the GPS receiver. Although multipath interference can occur even outside of a dense city environment (e.g., GPS signals may reflect off of clouds in the atmosphere even away from an urban setting), multipath interference can be especially problematic in an urban environment, where shadowing affects the received power of signals transmitted along the direct line-of-sight to the GPS receiver and where the received power from spurious reflected signals can become erroneously amplified. S120 may include detecting such multipath interference. For example, S120 may detect multipath interference by measuring a time-correlation function of received signals at the GPS receiver; since directly transmitted GPS signals and intermediately reflected GPS signals originate from the same signal source, they are likely to have similar signal features that are separated in time at the GPS receiver due to the fact that intermediately reflected GPS signals travel a longer distance to the GPS receiver. An example circuit which can be included in the GPS receiver and can measure such a time-correlation function is a delay lock loop (DLL), which measures the power difference between a first (‘early’) received signal and a second (‘late’) received signal as a function of time spacing in order to determine an Early-Late time spacing which maps the early and late signals onto each other. The DLL circuit outputs a voltage signal called a discriminator curve; by finding a zero of the discriminator curve (i.e., the time spacing at which the difference between the early and late signal power is zero), the DLL circuit can determine that there is an Early-Late time spacing which causes the discriminator to vanish. If the DLL circuit can find such a zero in the discriminator curve, this may be an indication of significant time-correlation between early and late signals; S120 may then be able to use this information to infer the presence of multipath effects. Alternatively, S120 may include detecting multipath interference in any suitable manner. In response to detecting multipath interference, S120 may then modify an operating state of the GPS receiver (e.g., switching the GPS receiver off to save battery power, decreasing the duty cycle of the GPS receiver to preserve power until multipath effects are diminished, etc.).


S120 may additionally or alternatively include modifying operating states of the GPS receiver in response to determining GPS position information is below a quality threshold in any other suitable manner. For example, the signal quality of the received signals at the GPS receiver can also be affected by the GPS satellite geometry. If two satellites nearly coincide with each other in the field-of-view of the GPS receiver, the inferred GPS receiver position determined from triangulation may have magnified errors as compared with two satellites which are further separated in the field-of-view. This geometric effect may be quantified in terms of a geometric dilution of precision (GDOP), which is defined as the ratio of errors incurred from satellite geometry to other errors incurred from signal measurement. Lower GDOP values (i.e., strong geometry) correspond to higher confidence (i.e., smaller errors) in the GPS measurements, while higher GDOP values (i.e., weak geometry) correspond to lower confidence (i.e., larger errors) in the GPS measurements. GDOP values greater than 20 may be an indication of poor GPS confidence/large GPS errors, but alternative GDOP thresholds may be used. In response to determining a high GDOP value, S120 may then modify an operating state of the GPS receiver (e.g., switching the GPS receiver off to save battery power, decreasing the duty cycle of the GPS receiver to preserve power until strong satellite geometry is restored, reorienting the GPS receiver relative to the GPS satellites to try to improve the satellite geometry in the field-of-view, etc.).


Navigation system operating states (as they pertain to GPS data collection) may be set based on any input data. For example, S120 may include collecting GPS data differently depending on navigation system battery state (e.g., charge level, charging status), time of day, location, route knowledge (e.g., how much data has been collected about the current route and/or position), GPS signal quality, or any other data.


S130 includes collecting supplementary data. S130 functions to collect data supplementary to GPS/GNSS data that may be used to perform navigation. Supplementary data preferably includes any data useful for navigation but not collected by the GPS receiver of the navigation device. For example, supplementary data may include visual data (e.g., images from a camera), audio data (e.g., ambient road noise), motion data (e.g., as measured by an IMU), atmospheric pressure data (e.g., as measured by a barometer) and/or altitude data (e.g., inferred from barometric data). Supplementary data may additionally or alternatively include location data received from other sources; for example, GPS data from a nearby GPS receiver (e.g., the GPS receiver of a smartphone in a nearby car) may be used as an approximate indicator of location. As another example, cell tower triangulation data (i.e., position data derived from radio tower triangulation or trilateration) or WiFi triangulation data may be used as an approximate indicator of location.


S130 preferably functions to collect supplementary data when necessary for navigation and/or route learning purposes. As most supplementary data collection techniques draw substantially less power than GPS-based navigation, S130 may include performing supplementary data collection substantially more frequently than GPS data collection. Additionally or alternatively, S130 may include collecting and/or storing supplementary data at any frequency.


S130 may include processing supplementary data; for example, raw accelerometer data may be translated into measured accelerations. As another example, S130 may include performing feature recognition on audio and/or video data to identify motion changes. As a third example, S130 may include interpreting barometer data based on weather conditions (e.g., as received from an internet-accessible weather report). As a fourth example, S130 may include interpreting magnetometer data to detect changes in vehicle heading (e.g., turns taken by a vehicle).


In one variation of a preferred embodiment, S130 may include processing accelerometer data in order to isolate accelerometer data corresponding to vertical vehicular motion (e.g., vehicular motion perpendicular a road surface). Vertical vehicular motion data preferably includes time, vertical vehicular acceleration, and vertical vehicular velocity but may further include or exclude other data related to vertical vehicular motion. Isolating vertical vehicular motion may be useful as a characteristic signature of a geophysical location; for example, if a particular road surface includes a pothole of a particular depth, vertical vehicular motion data acquired as the vehicle traverses the pothole may be characteristic of the geophysical position of the pothole and may be used to estimate the location of the vehicle without the use of GPS. Other road surface characteristics useful for identifying location may include speed bumps, for instance. In order to discern robust characteristic profiles from the vertical vehicular motion data, S130 may include acquiring data from multiple trips at a given location in order to extract the characteristic profile features in the vertical vehicular motion data; alternatively, S130 may acquire data from a single trip at a given location to infer a characteristic vertical vehicular motion profile (e.g., the characteristic profile in the vertical vehicular motion data may be distinct enough from a single trip). S130 may further include post-processing the acquired data (e.g., data filtering, data smoothing, data averaging, etc.) in order to, for example, filter out noise and/or isolate intrinsic features of the characteristic profile.


In a specific example of post-processing vertical vehicular motion data in order to discern robust profiles that are characteristics of geophysical locations, S130 may further include calibrating the vertical vehicular motion data for the suspension of the vehicle (i.e., how road surface features register as a vertical vehicular motion response as recorded by the navigation device). In cases in which S130 cannot leverage any specific information about vehicle suspension, S130 may accomplish suspension calibration relative to a baseline suspension profile default; this profile may represent the average vertical vehicular response inferred from all vertical vehicular motion data accessible to the navigation device but may alternatively be established in any suitable manner. In an instance in which a reference position is known (e.g., via GPS location) and is associated with a specific vertical vehicular motion profile, S130 may include comparing the associated vertical vehicular motion profile to a measured vertical vehicular motion profile based on accelerometer data (i.e., without a suspension calibration) and determining a suspension calibration profile based on a suspension-related difference. In an instance in which the navigation device can leverage information about the vehicle suspension, S130 may use such information to retrieve a corresponding stored calibration profile and calibrate the vertical vehicular motion data according to the corresponding stored calibration profile. For example, vehicle suspension may be characteristic of a particular vehicle manufacturer (e.g., a vehicle manufactured by Ford may have a characteristic suspension response different from that of a vehicle manufactured by Chevrolet), of a particular vehicle type (e.g., an SUV may have a characteristic suspension response different from that of a sedan), of a particular vehicle (e.g., a particular vehicle may have a characteristic suspension response different from that of another vehicle, even if the other vehicle is manufactured by the same manufacturer and is of the same vehicle type), of a particular vehicle weight, or of any other suitable vehicular parameter. S130 may detect any suitable vehicular parameter in any suitable manner; for example, S130 may detect suitable vehicular parameters via direct user-input (e.g., through a user-interface associated with the navigation device), detection (e.g., the navigation device may be able to interface with an electronic control unit of the vehicle wirelessly, e.g., via radio or Bluetooth, to determine suitable vehicular parameters), inference (e.g., monitored vehicular performance during travel), or in any other suitable manner.


In another variation of a preferred embodiment, S130 may further include processing accelerometer data in order to isolate accelerometer data corresponding to horizontal vehicular motion (e.g., vehicular motion parallel a road surface). Horizontal vehicular motion data preferably includes time, horizontal vehicular acceleration, and horizontal vehicular velocity but may further include or exclude other data related to horizontal vehicular motion. As shown in FIGS. 4A, 4B, and 4C, such horizontal vehicular data may be useful since vertical vehicular motion data may need to be scaled based on horizontal vehicular speed in order to be correlated with characteristic vehicular motion profiles. As shown in FIG. 4A, a first set of vertical vehicular motion data may correspond to a vehicle traveling at a first horizontal velocity across a certain geophysical region; however, as shown in FIG. 4B, a second (potentially, but not necessarily, different) set of vertical vehicular motion data may correspond to the same vehicle traveling across the same geophysical region but at a faster horizontal speed. As shown in FIG. 4C, the vertical vehicular motion profile associated with that geophysical region may have been collected at a third, potentially intermediate, horizontal velocity. Although, as shown in FIGS. 4A, 4B, and 4C, the vertical vehicular motion response is schematically represented as increasing with increasing horizontal vehicular speed, the vertical vehicular motion response may decrease or be completely uncorrelated with horizontal vehicular speed. If the vertical vehicular motion data depends in any manner on the horizontal vehicular speed as a function of location, S130 may include scaling the vertical vehicular motion data in light of the horizontal vehicular motion data in any suitable manner.


In another specific example and as shown in FIGS. 5A, 5B, and 5C, such horizontal vehicular data may additionally be useful since a characteristic vehicular motion profile may correspond to a narrower vertical motion response in time as the horizontal vehicular velocity increases. As shown in FIG. 5A, a first set of vertical vehicular motion data may correspond to a vehicle traveling across a geophysical region at a first horizontal velocity as a function of time; however, as shown in FIG. 5B, a second (potentially, but not necessarily, different) set of vertical vehicular motion data may correspond to the same vehicle traveling across the same geophysical region as a function of time but at a faster horizontal speed. As shown in FIG. 5C, the vertical vehicular motion profile associated with that geophysical region as a function of time may have been collected at a third, potentially intermediate, horizontal velocity. If the vertical vehicular motion data depends in any manner on the horizontal vehicular speed as a function of time, S130 may include time-scaling the characteristic vertical motion profiles in order to account for the dependence of the vertical vehicular motion profile on the horizontal vehicular motion; without time-scaling, for example, the ability of S130 to estimate a vehicle location from the vertical vehicular motion data may be affected.


In another specific example, S130 may include using horizontal vehicular motion data in order to infer a horizontal vehicular direction of travel. S130 may include incorporating the horizontal vehicular direction of travel in estimating a vehicular location based on the vertical vehicular motion data. For example, if S130 uses the vertical vehicular motion data to estimate a location of the vehicle and generates two likely locations of equal probability based on the vertical vehicular motion profile, S130 may include using the horizontal vehicular direction of travel to decide between them (e.g., if the vehicle is traveling towards one of the locations and away from the other location). Additionally or alternatively, S130 may include using horizontal vehicular motion data in any suitable manner.


In another variation of a preferred embodiment, S130 may include collecting and processing barometer data. Barometer data may be comparatively insensitive to local navigation device movement relative to accelerometer data (e.g., comparatively less affected by the user interacting with the navigation device); barometer data in combination with accelerometer data may then improve location estimates based primarily on either barometer or accelerometer data in isolation. However, S130 may include using primarily or solely a single source of supplementary data. Although barometric pressure readings associated with the location of the vehicle may be characteristic of that location (e.g., the location's altitude), the barometric pressure data may also be affected by extrinsic factors uncharacteristic of the particular location (e.g., weather); therefore, S130 may include processing barometer data in order to correct for these extrinsic factors. In a specific example where the extrinsic factor affecting barometric pressure is weather, S130 may include acquiring weather-associated pressure data (e.g., via the navigation device by retrieving the data from a local weather source over the internet) and correcting barometer data in light of the weather-associated pressure data. S130 may additionally include any suitable barometer processing step (e.g., time averaging, noise filtering, aggregating weather-associated pressure data from multiple sources, etc.). For example, S130 may include calculating change in barometric pressure or normalized barometric pressure (e.g., normalizing barometric pressure to an initial barometric pressure or looking at changes to remove error introduced by weather effects, for instance).


S130 may additionally or alternatively include modifying navigation system operating states as they pertain to supplementary data collection (e.g., choosing to store sensor data or not, frequency of supplementary data collection, processing parameters, etc.). Navigation system operating states (as they pertain to supplementary data collection) may be set based on any input data. For example, S130 may include collecting supplementary data differently depending on navigation system battery state (e.g., charge level, charging status), time of day, location, route knowledge (e.g., how much data has been collected about the current route and/or position), GPS signal quality, or any other data.


S140 includes associating the GPS data and the supplementary data. S140 functions to link supplementary data to position; in most cases, GPS data is the initial source of this position data. For example, S140 may include associating specific accelerometer or barometer responses with specific positions (as determined by GPS).


S140 may include associating GPS data and supplementary data in any manner; for example, GPS data may be used to correlate supplementary data to a position. In this example, a particular supplementary data profile (e.g., a specific turning pattern as measured by an accelerometer) may be correlated to a specific position or area (as measured by GPS) so that in the future, if this supplementary data profile is detected, the navigation system location may be derived without use of GPS.


One example of a preferred embodiment includes using GPS data to provide initial position measurements which S140 can then use in estimating vehicular position based on the supplementary data. For example, S140 may include calculating an estimated location of the vehicle based on vertical vehicular motion data and then compare this estimated location to the GPS initialized position. If the estimated location of the vehicle based on vertical vehicular motion includes one candidate location in San Francisco and another candidate location in Oakland, S140 may leverage GPS initialized data localizing the vehicle to San Francisco in the calculation of the estimated location of the vehicle (i.e., locality may be used in weighting or scoring candidate locations).


As another example, GPS data may be used to provide initial position measurements, from which motion measurements may be used to perform dead reckoning or a similar technique. Dead reckoning refers to a process for calculating a change in position based on motion data (e.g., without directly measuring position via GPS); by measuring vehicular velocity as a function of time (or inferring vehicular velocity from accelerometer measurements), a change in position can be calculated via time integration. Dead reckoning may be used for estimating the location of the vehicle on a road surface; in this case, dead reckoning may specifically leverage horizontal vehicular motion data to estimate a change in horizontal vehicular position relative to a road surface. If S140 includes dead reckoning to estimate a change in vehicular position, the result of dead reckoning may be used for a variety of purposes.


In a first specific example, S140 may include dead reckoning in order to produce a vehicular location estimate separate from the vehicular location estimate based on vertical vehicular motion data. In this specific example, S140 may include receiving an initial position from a GPS receiver, using dead reckoning to estimate a change in vehicular position that can be added to the initial position to produce a GPS-and-accelerometer-derived location estimate, and comparing the GPS-and-accelerometer-derived location estimate to the estimated vehicular location derived from vertical vehicular motion data in light of the mapping association. Particularly in cases in which S140 selects the estimated vehicular location derived from vertical vehicular motion data from a set of potential locations with comparable likelihoods, S140 may include the comparison of the GPS-and-accelerometer-derived location estimate to the estimated vehicular location derived from vertical vehicular motion data in calculating the estimated location of the vehicle (e.g., averaging the GPS-and-accelerometer-derived location estimate and the estimated vehicular location derived from vertical vehicular motion data, adjusting probability or confidence weights associated with each member of the set of potential vertical vehicular motion locations in light of the GPS-and-accelerometer-derived location estimate, averaging the estimates according to the confidence weights, etc.). S140 may also include choosing between the GPS-and-accelerometer-derived location estimate and the estimated vehicular location derived from vertical vehicular motion data based on a calculated confidence level in either estimate. For example, if the GPS-and-accelerometer-derived location estimate corresponds to a location in the middle of the ocean due to an initial position error arising from GPS poor GPS satellite geometry, S140 may include assigning a low confidence to the GPS-and-accelerometer-derived location estimate (e.g., where the confidence assignment is based on a calculation of the GDOP value associated with the received GPS signal) and choosing the estimated vehicular location derived from vertical vehicular motion data based on a higher associated confidence. In a separate context, instead of choosing between different location estimates, S140 may include weighting the different estimates according to an estimated confidence weight and taking the confidence-weighted average as the estimated vehicular location.


In a second specific example, S140 may include dead reckoning to calculate a location estimate error from the vertical vehicular motion data. If the vehicle starts at a known location (e.g., known via GPS), S140 may include dead reckoning to estimate a vehicular location by adding the known location to the vehicle position change calculated from dead reckoning to produce a GPS-and-accelerometer-derived location estimate; when the GPS-and-accelerometer-derived location estimate is similar to the location estimated from vertical vehicular motion data, S140 may be able to use this information to conclude that the location estimate error from vertical vehicular motion data is low (e.g., the error is below some threshold, the confidence in the prediction is higher than some threshold confidence, etc.) and take a corresponding action (e.g., modify an operating state of the GPS receiver, navigate primarily using supplementary data, etc.). S140 may also include calculating a location estimate error in any other suitable manner (e.g., by direct comparison of the location estimate from vertical vehicular data to a GPS-derived location estimate).


S140 may also include dead reckoning for any other suitable purpose.


GPS data is preferably associated with supplementary data on a time basis; that is, GPS data is associated with supplementary data taken within a certain time period (e.g., a few seconds) of the GPS data. Subsequent supplementary data taken at a future time (e.g., a month later) may then be compared to earlier supplementary data (e.g., analyzed for correlations); S140 preferably includes using that comparison and the GPS association with the earlier supplementary data to estimate location based on the supplementary data at the future time. The estimated location based on the comparison of earlier and subsequent supplementary data can be performed in any suitable manner. For example, calculating the estimated location of the vehicle may include generating a set of potential locations, each potential location associated with a supplementary data profile. In some specific examples, S140 may calculate the estimated location of the vehicle solely based on correlations between the set of supplementary data profiles from the potential locations and supplementary data taken at the time of travel (e.g., real-time vertical vehicular motion data, real-time barometer data, etc.); alternatively, S140 may also use additional information (etc., proximity to a GPS-measured initial vehicular location, combination with a GPS-and-accelerometer-derived location inferred from dead reckoning, etc.) in calculating the estimated location of the vehicle. S140 may also include calculating the estimated location of the vehicle based on the comparison in any suitable manner (e.g., averaging the different estimates, performing a weighted-average of the estimates based on a probability weight, performing a weighted-average of the estimates based on a confidence weight corresponding to any of the estimation methods, etc.). Additionally or alternatively, GPS data may be associated with supplementary data in any manner.


GPS data is preferably associated with processed supplementary data (described in more detail below), but may additionally or alternatively be associated with unprocessed supplementary data.


S140 preferably includes performing supplementary data processing and/or filtering. Supplementary data processing preferably attempts to identify patterns or events within supplementary data that correspond either to a particular position/area or to a motion associated with a particular position. As an example of position correspondence, the road surface of a particular stretch of road may have a characteristic profile identifiable by accelerometer readings (of navigation systems located in cars traveling that stretch of road). As an example of motion correspondence, a particular curve in a road may result in a predictable and distinct driver turning response (identifiable by accelerometer and/or gyroscope data).


These correspondences may be formed in a number of ways; for example, a correspondence may be formed when a supplementary data pattern is associated with a position repeatedly (e.g., the pattern may not be explicitly identified, but it occurs every time in a particular position as measured by GPS, observed over five separate times). As another example, a correspondence may be formed by feature recognition (e.g., the pattern looks like a right hand turn with a particular radius of curvature, which can be matched to a road present in navigation map data based on profile and GPS position), as shown in FIG. 6.


In cases where S140 includes performing feature recognition, S140 preferably first includes performing feature identification. For example, in the previous example, S140 may include first identifying that a particular accelerometer data pattern identifies a right hand turn, and after said identification, then comparing the right hand turn to navigation map road curvature data.


Feature identification may also be used to remove noise (and/or any other undesired signal components) from supplementary data. For example, S140 may include detecting that motion data recorded by a smartphone's accelerometer resulted from a user moving the phone within the car (rather than a motion of the car itself); signal associated with this motion may be removed from the supplementary data used for navigation purposes. As another example, S140 may include detecting a lane change during a turn, and transforming the motion data to better reflect the curvature of the turn (instead of the raw data, which includes motion due to both the turn and the lane change). In some cases, noise may not be easily removable (e.g., cases where noise overwhelms signal), and S140 may include discarding noisy supplementary data.


S140 may also include using feature identification to modify how supplementary data is stored and/or associated. For example, S140 may include correlating z-axis vehicle motion (which is measured by an accelerometer and/or a barometer, and corresponds to variance in height across the road surface) to position on a road. Road surface may be a function of not only position along a road (i.e., in the direction of travel), but also of position across a road (i.e., which lane the vehicle is in and potentially even position within the lane). Resultantly, data may need to be measured across all lanes (in a particular direction) to provide a good correlation between road surface and position along the road. In this example, S140 may include storing data separately for lanes; therefore, S140 may use feature identification of a lane change to modify for which lane data is stored.


Feature identification may be performed in any suitable manner. As a first example, feature identification may include comparing supplementary data to supplementary data of the same type (e.g., accelerometer data is compared to other accelerometer data) tagged as representative of a particular feature. As a second example, feature identification may include algorithmically processing supplementary data to evaluate it for certain characteristics. As a third example, feature identification may include performing a preliminary correspondence between supplementary data of one type and data of another type (e.g., other supplementary data, GPS data, etc.) and then identifying a feature in the supplementary data of the first type based on feature identification run on data of the second type. As a fourth example, feature identification may include receiving explicit feature identification from a user (e.g., a user presses a button identifying that the user just made a right hand turn).


S140 may include performing supplementary data processing by corroborating multiple sources. For example, S140 may include receiving vehicle speedometer data (e.g., via an OBD-II interface) in addition to accelerometer data from a smartphone accelerometer; if the smartphone accelerometer records a large change in acceleration not noted by the speedometer, that may indicate that the smartphone is in motion relative to the vehicle (and this accelerometer data may be processed/filtered accordingly).


As another example, S140 may include adjusting supplementary data based on vehicle speed (which in some cases may be obtained via the GPS receiver of the navigation system). Time-scaling of vertical vehicular motion data is one example, but S140 may additionally or alternatively include adjusting supplementary data based on vehicle speed in any suitable manner (e.g., speed-adjusted barometer measurements due to air motion relative to a moving vehicle).


As shown in previous examples, supplementary data collection may experience a high degree of variability based on collection mechanisms used. S140 preferably includes associating GPS data and supplementary data in a manner adjusted to account for some of this variability.


For example, if accelerometer data is collected by a smartphone, the data may vary significantly based on position and orientation of the smartphone within the vehicle. S140 may include automatically adjusting collected data to account for this; additionally or alternatively, S140 may include requesting that a user position the smartphone in a particular manner.


Likewise, supplementary data collected by a mobile navigation system may vary based on the driver and/or the vehicle the mobile navigation system is associated with. S140 may include modifying supplementary data based on vehicle and/or driver; for example, if S140 includes associating road surface measurement (as detected by accelerometer) with position, the suspension response of the vehicle may need to be taken into account to allow data taken in one vehicle to be compared to another.


S140 may include identifying a vehicle and/or driver of the vehicle by asking the navigation system user to identify the vehicle and/or driver. Additionally or alternatively, S140 may include identifying a vehicle and/or driver automatically.


In one implementation of a preferred embodiment, S140 includes identifying a vehicle and/or driver automatically as shown in FIG. 7, and as described in U.S. patent application Ser. No. 14/206,721, the entirety of which is incorporated by this reference.


S150 includes performing navigation based on the supplementary data. S150 functions to perform vehicle navigation according to supplementary data, but may perform navigation based solely on supplementary data or based on a combination of both supplementary data and GPS data (and/or any other relevant data). S150 preferably includes performing navigation by comparing position (e.g., latitude and longitude, relative position compared to roads, etc.) as computed from supplementary data to map data, but may additionally or alternatively include performing navigation in any manner.


S150 preferably includes performing navigation (e.g., providing a user with directions, providing directions to a self-driving car, etc.) according to the navigation system state, as previously described. The navigation system state preferably determines how supplementary data and GPS data are used to perform navigation, as well as supplementary data and GPS data collection parameters. The navigation state may also determine how supplementary data and GPS data are processed and/or calibrated or for any other suitable purpose.


In one variation of a preferred embodiment, S150 includes suggesting road lanes for a vehicle to occupy. For example, if S140 enables the identification of the lane a vehicle is traveling in, S150 may include directing vehicles to occupy a particular lane (e.g., occupy the right-hand lane to make a particular turn).


The system and methods of the preferred embodiment and variations thereof can be embodied and/or implemented at least in part as a machine configured to receive a computer-readable medium storing computer-readable instructions. The instructions are preferably executed by computer-executable components preferably integrated with a navigation system. The computer-readable medium can be stored on any suitable computer-readable media such as RAMs, ROMs, flash memory, EEPROMs, optical devices (CD or DVD), hard drives, floppy drives, or any suitable device. The computer-executable component is preferably a general or application specific processor, but any suitable dedicated hardware or hardware/firmware combination device can alternatively or additionally execute the instructions.


As a person skilled in the art will recognize from the previous detailed description and from the figures and claims, modifications and changes can be made to the preferred embodiments of the invention without departing from the scope of this invention defined in the following claims.

Claims
  • 1. A method for estimating a location of a vehicle, the method comprising: for a first trip of the vehicle along a first route: receiving a first sensor dataset from a first sensor of a mobile user device;receiving a second sensor dataset from a second sensor of the mobile user device;determining a first set of vertical vehicular data based on the second sensor dataset, wherein determining the first set of vertical vehicular data comprises scaling the second sensor dataset based on a vehicular speed;generating a mapping between the first sensor dataset and the first set of vertical vehicular data;for a second trip of the vehicle along a second route; collecting a third sensor dataset from the first sensor of the mobile user device;collecting a fourth sensor dataset from the second sensor of the mobile user device;detecting that the second route is the same as the first route;in response to detecting that the second route is the same as the first route, adjusting a sampling rate of the first sensor; anddetermining an estimated location of the vehicle based on the fourth sensor dataset and the mapping.
  • 2. The method of claim 1, wherein adjusting the sampling rate of the first sensor comprises decreasing a sampling rate of the first sensor.
  • 3. The method of claim 2, wherein adjusting the sampling rate of the first sensor further comprises switching off the first sensor.
  • 4. The method of claim 1, wherein the first sensor is a location sensor.
  • 5. The method of claim 4, wherein each of the first and third sensor datasets comprises a set of GPS locations.
  • 6. The method of claim 4, wherein the second sensor is at least one of an accelerometer and a barometer.
  • 7. The method of claim 1, further comprising automatically determining an identity of a driver of the vehicle of the second trip, wherein detecting that the second route is the same as the first route is performed at least in part based on the identity of the driver.
  • 8. The method of claim 1, further comprising determining a second set of vertical vehicular data based on the fourth sensor dataset, wherein the estimated location of the vehicle is further determined based on the second set of vertical vehicular data.
  • 9. The method of claim 1, wherein detecting that the second route is the same as the first route is performed based on at least one of the third and fourth sensor datasets.
  • 10. A method for estimating a location of a vehicle, the method comprising: receiving a mapping between a first set of vertical vehicular data and a set of locations;collecting a supplementary sensor dataset from a supplementary sensor of the user device;determining a second set of vertical vehicular data based on the supplementary sensor dataset, wherein determining the second set of vertical vehicular data comprises scaling the supplementary sensor dataset based on a vehicular speed;detecting that the second set of vertical vehicular data is a subset of the first set of vertical vehicular data;in response to detecting that the second set of vertical vehicular data is a subset of the first set of vertical vehicular data, adjusting a sampling rate of a location sensor of the user device; anddetermining an estimated location of the vehicle based on the second set of vertical vehicular data and the mapping.
  • 11. The method of claim 10, wherein the user device is a mobile user device.
  • 12. The method of claim 11, wherein the mobile user device is a smartphone.
  • 13. The method of claim 10, wherein the estimated location is further determined based on a location dataset from the location sensor of the user device, the location dataset collected at the adjusted sampling rate.
  • 14. The method of claim 13, wherein the location dataset comprises a set of GPS locations.
  • 15. The method of claim 10, wherein the supplementary sensor is at least one of an accelerometer and a barometer.
  • 16. The method of claim 10, wherein adjusting the sampling rate of the location sensor of the user device comprises decreasing a sampling rate of the location sensor of the user device.
  • 17. The method of claim 16, wherein adjusting the sampling rate of the location sensor of the user device further comprises switching off the location sensor of the user device.
  • 18. The method of claim 10, further comprising automatically determining an identity of a driver of the vehicle, wherein detecting that the second set of vertical vehicular data is a subset of the first set of vertical vehicular data is performed at least in part based on the identity of the driver.
  • 19. The method of claim 18, wherein the driver is associated with a set of commonly driven trips.
  • 20. The method of claim 19, wherein the second set of vertical vehicular data is associated with one of the set of commonly driven trips.
CROSS-REFERENCE TO RELATED APPLICATIONS

This application is a continuation of U.S. patent application Ser. No. 16/240,183, filed 4 Jan. 2019, which is a continuation of U.S. patent application Ser. No. 15/652,558, filed 18 Jul. 2017, which is a continuation of U.S. patent application Ser. No. 15/243,513, filed 22 Aug. 2016, which claims the benefit of U.S. Provisional Application Ser. No. 62/207,461, filed on 20 Aug. 2015, which are each incorporated in their entirety by this reference.

US Referenced Citations (244)
Number Name Date Kind
4100795 Panetti Jul 1978 A
5673039 Pietzsch et al. Sep 1997 A
6049778 Walker et al. Apr 2000 A
6055477 McBurney et al. Apr 2000 A
6826477 Ladetto et al. Nov 2004 B2
6941222 Yano et al. Sep 2005 B2
7065449 Brewster et al. Jun 2006 B2
7532196 Hinckley May 2009 B2
7668931 Parupudi et al. Feb 2010 B2
7801675 Currie et al. Sep 2010 B2
7881868 Greene et al. Feb 2011 B2
8054168 McCormick et al. Nov 2011 B2
8264375 Devries Sep 2012 B2
8290480 Abramson et al. Oct 2012 B2
8326257 Shiu et al. Dec 2012 B2
8352189 Scott et al. Jan 2013 B2
8369876 Bachmann et al. Feb 2013 B2
8395542 Scherzinger et al. Mar 2013 B2
8489330 Ellanti et al. Jul 2013 B2
8498610 Staehlin Jul 2013 B2
8504035 Shin et al. Aug 2013 B2
8521193 Paek et al. Aug 2013 B2
8577703 McClellan et al. Nov 2013 B2
8634822 Silver et al. Jan 2014 B2
8731530 Breed et al. May 2014 B1
8738523 Sanchez et al. May 2014 B1
8754766 Desterling et al. Jun 2014 B2
8912103 Heo et al. Dec 2014 B2
8971927 Zhou et al. Mar 2015 B2
8972103 Elwart et al. Mar 2015 B2
8989914 Nemat-Nasser et al. Mar 2015 B1
8996234 Tamari et al. Mar 2015 B1
9064412 Baur Jun 2015 B2
9121940 Psiaki et al. Sep 2015 B2
9141974 Jones et al. Sep 2015 B2
9185526 Guba et al. Nov 2015 B2
9188451 Magnusson et al. Nov 2015 B2
9221428 Kote et al. Dec 2015 B2
9222798 Curtis et al. Dec 2015 B2
9224293 Taylor Dec 2015 B2
9250090 Hille et al. Feb 2016 B2
9311211 Chatterjee et al. Apr 2016 B2
9311271 Wright Apr 2016 B2
9360323 Grokop Jun 2016 B2
9368027 Jang et al. Jun 2016 B2
9390625 Green et al. Jul 2016 B2
9414221 Simon et al. Aug 2016 B1
9423318 Liu et al. Aug 2016 B2
9449495 Call et al. Sep 2016 B1
9457754 Christensen et al. Oct 2016 B1
9467515 Penilla et al. Oct 2016 B1
9495601 Hansen Nov 2016 B2
9536428 Wasserman Jan 2017 B1
9558520 Peak et al. Jan 2017 B2
9566981 Rebhan et al. Feb 2017 B2
9587952 Slusar Mar 2017 B1
9628975 Watkins et al. Apr 2017 B1
9632507 Korn Apr 2017 B1
9633487 Wright Apr 2017 B2
9645970 Boesch et al. May 2017 B2
9650007 Snyder et al. May 2017 B1
9674370 Kim et al. Jun 2017 B2
9689698 Wesselius et al. Jun 2017 B2
9716978 Sankaran Jul 2017 B2
9731713 Horii Aug 2017 B2
9773281 Hanson Sep 2017 B1
9794729 Meyers et al. Oct 2017 B2
9800716 Abramson et al. Oct 2017 B2
9801027 Levy et al. Oct 2017 B2
9805601 Fields et al. Oct 2017 B1
9818239 Pal et al. Nov 2017 B2
9842120 Siris et al. Dec 2017 B1
9852475 Konrardy et al. Dec 2017 B1
9854396 Himmelreich et al. Dec 2017 B2
9868394 Fields et al. Jan 2018 B1
9870649 Fields et al. Jan 2018 B1
9888392 Snyder et al. Feb 2018 B1
9900747 Park Feb 2018 B1
9932033 Slusar et al. Apr 2018 B2
9967701 Barfield, Jr. May 2018 B1
9994218 Pal et al. Jun 2018 B2
10137889 Pal et al. Nov 2018 B2
10176524 Brandmaier et al. Jan 2019 B1
10304329 Matus et al. May 2019 B2
10324463 Konrardy et al. Jun 2019 B1
10386192 Konrardy et al. Aug 2019 B1
10510123 Konrardy et al. Dec 2019 B1
10533870 Slusar Jan 2020 B1
10824145 Konrardy et al. Nov 2020 B1
10885592 Hsu-Hoffman et al. Jan 2021 B2
10983523 Sim Apr 2021 B2
11170446 Thurber Nov 2021 B1
20020161517 Yano et al. Oct 2002 A1
20030018430 Ladetto et al. Jan 2003 A1
20040046335 Knox et al. Mar 2004 A1
20040082311 Shiu et al. Apr 2004 A1
20050080555 Parupudi et al. Apr 2005 A1
20050093868 Hinckley May 2005 A1
20050197773 Brewster et al. Sep 2005 A1
20060153198 Chadha Jul 2006 A1
20070005228 Sutardja Jan 2007 A1
20070208494 Chapman et al. Sep 2007 A1
20070208501 Downs et al. Sep 2007 A1
20080033776 Marchese Feb 2008 A1
20080103907 Maislos et al. May 2008 A1
20080243439 Runkle et al. Oct 2008 A1
20080312832 Greene et al. Dec 2008 A1
20090024419 McClellan et al. Jan 2009 A1
20100030582 Rippel et al. Feb 2010 A1
20100056175 Bachmann et al. Mar 2010 A1
20100100398 Auker et al. Apr 2010 A1
20100106406 Hille et al. Apr 2010 A1
20100198517 Scott et al. Aug 2010 A1
20100219944 Mc et al. Sep 2010 A1
20100273508 Parata et al. Oct 2010 A1
20100299021 Jalili Nov 2010 A1
20100332131 Horvitz et al. Dec 2010 A1
20110077028 Wilkes et al. Mar 2011 A1
20110124311 Staehlin May 2011 A1
20110161116 Peak et al. Jun 2011 A1
20110246156 Zecha et al. Oct 2011 A1
20110294520 Zhou et al. Dec 2011 A1
20120050095 Scherzinger et al. Mar 2012 A1
20120065871 Deshpande et al. Mar 2012 A1
20120066053 Agarwal Mar 2012 A1
20120071151 Abramson et al. Mar 2012 A1
20120089328 Ellanti et al. Apr 2012 A1
20120109517 Watanabe May 2012 A1
20120129545 Hodis et al. May 2012 A1
20120136529 Curtis et al. May 2012 A1
20120136567 Wang et al. May 2012 A1
20120149400 Paek et al. Jun 2012 A1
20120158820 Bai et al. Jun 2012 A1
20120197587 Luk et al. Aug 2012 A1
20120226421 Kote et al. Sep 2012 A1
20120245963 Peak et al. Sep 2012 A1
20130006469 Green et al. Jan 2013 A1
20130041521 Basir et al. Feb 2013 A1
20130052614 Mollicone et al. Feb 2013 A1
20130069802 Foghel et al. Mar 2013 A1
20130096731 Tamari et al. Apr 2013 A1
20130124074 Horvitz et al. May 2013 A1
20130130639 Oesterling et al. May 2013 A1
20130204515 Emura Aug 2013 A1
20130211618 Iachini Aug 2013 A1
20130289819 Hassib et al. Oct 2013 A1
20130302758 Wright Nov 2013 A1
20130316737 Guba et al. Nov 2013 A1
20130317860 Schumann Nov 2013 A1
20130325517 Berg Dec 2013 A1
20130332357 Green et al. Dec 2013 A1
20130344856 Silver et al. Dec 2013 A1
20140038640 Wesselius et al. Feb 2014 A1
20140046896 Potter Feb 2014 A1
20140074402 Hassib et al. Mar 2014 A1
20140081670 Lim et al. Mar 2014 A1
20140188638 Jones et al. Jul 2014 A1
20140197967 Modica et al. Jul 2014 A1
20140207497 Collins et al. Jul 2014 A1
20140232592 Psiaki et al. Aug 2014 A1
20140244150 Boesch et al. Aug 2014 A1
20140244156 Magnusson et al. Aug 2014 A1
20140288765 Elwart et al. Sep 2014 A1
20140288828 Werner et al. Sep 2014 A1
20140323160 Venkatraman Oct 2014 A1
20140358394 Picciotti Dec 2014 A1
20150025917 Stempora Jan 2015 A1
20150046197 Peng et al. Feb 2015 A1
20150084757 Annibale et al. Mar 2015 A1
20150087264 Goyal Mar 2015 A1
20150097703 Baur Apr 2015 A1
20150229666 Foster et al. Aug 2015 A1
20150233718 Grokop Aug 2015 A1
20150246654 Tadic et al. Sep 2015 A1
20150327034 Abramson et al. Nov 2015 A1
20150332407 Wilson et al. Nov 2015 A1
20150334545 Maier et al. Nov 2015 A1
20160021238 Abramson et al. Jan 2016 A1
20160033366 Liu et al. Feb 2016 A1
20160042767 Araya et al. Feb 2016 A1
20160048399 Shaw Feb 2016 A1
20160059855 Rebhan et al. Mar 2016 A1
20160066155 Fan Mar 2016 A1
20160068156 Horii Mar 2016 A1
20160086285 Jordan et al. Mar 2016 A1
20160129913 Boesen May 2016 A1
20160150070 Goren et al. May 2016 A1
20160171521 Ramirez et al. Jun 2016 A1
20160174049 Levy et al. Jun 2016 A1
20160189303 Fuchs Jun 2016 A1
20160189442 Wright Jun 2016 A1
20160225263 Salentiny et al. Aug 2016 A1
20160232785 Wang Aug 2016 A1
20160269852 Meyers et al. Sep 2016 A1
20160272140 Kim et al. Sep 2016 A1
20160282156 Ott et al. Sep 2016 A1
20160325756 Cordova et al. Nov 2016 A1
20160328893 Cordova et al. Nov 2016 A1
20160339910 Jonasson et al. Nov 2016 A1
20160358315 Zhou et al. Dec 2016 A1
20160364983 Downs et al. Dec 2016 A1
20160375908 Biemer Dec 2016 A1
20160379310 Madigan et al. Dec 2016 A1
20160379485 Anastassov et al. Dec 2016 A1
20160381505 Sankaran Dec 2016 A1
20170034656 Wang et al. Feb 2017 A1
20170053461 Pal et al. Feb 2017 A1
20170097243 Ricci Apr 2017 A1
20170103342 Rajani et al. Apr 2017 A1
20170103588 Rajani et al. Apr 2017 A1
20170105098 Cordova et al. Apr 2017 A1
20170115125 Outwater et al. Apr 2017 A1
20170116792 Jelinek et al. Apr 2017 A1
20170124660 Srivastava May 2017 A1
20170126810 Kentley et al. May 2017 A1
20170138737 Cordova et al. May 2017 A1
20170164158 Watkins et al. Jun 2017 A1
20170178416 Barreira Avegliano et al. Jun 2017 A1
20170178422 Wright Jun 2017 A1
20170178424 Wright Jun 2017 A1
20170210323 Cordova et al. Jul 2017 A1
20170211939 Cordova et al. Jul 2017 A1
20170232963 Pal et al. Aug 2017 A1
20170234689 Gibson et al. Aug 2017 A1
20170241791 Madigan et al. Aug 2017 A1
20170279947 Rajakarunanayake et al. Sep 2017 A1
20170289754 Anderson et al. Oct 2017 A1
20170369055 Saigusa et al. Dec 2017 A1
20170371608 Wasserman Dec 2017 A1
20180061230 Madigan et al. Mar 2018 A1
20180075309 Sathyanarayana et al. Mar 2018 A1
20180090001 Fletcher Mar 2018 A1
20180154908 Chen Jun 2018 A1
20180165531 Sathyanarayana et al. Jun 2018 A1
20180174446 Wang Jun 2018 A1
20180276485 Heck et al. Sep 2018 A1
20180308128 Deluca et al. Oct 2018 A1
20190007511 Rodriguez et al. Jan 2019 A1
20190035266 Riess et al. Jan 2019 A1
20190281416 Watkins et al. Sep 2019 A1
20190295133 Hirtenstein et al. Sep 2019 A1
20210309261 Rosales et al. Oct 2021 A1
20220005291 Konrardy et al. Jan 2022 A1
20220180448 Konrardy et al. Jun 2022 A1
Foreign Referenced Citations (16)
Number Date Country
3439000 Apr 1986 DE
102008008555 Aug 2008 DE
0534892 Mar 1993 EP
3638542 Jan 2022 EP
2492369 Apr 2014 GB
2000009482 Jan 2000 JP
2002215236 Jul 2002 JP
2005098904 Apr 2005 JP
2007212265 Aug 2007 JP
2009133702 Jun 2009 JP
2011133240 Jul 2011 JP
2013195143 Sep 2013 JP
2013200223 Oct 2013 JP
20130106106 Sep 2013 KR
2004085220 Oct 2004 WO
2006000166 Jan 2006 WO
Non-Patent Literature Citations (14)
Entry
European Patent Office Search Report for Application No. 16837957.6 dated Feb. 5, 2021.
European Patent Office Search Report for Application No. 16837957.6 dated Jun. 30, 2020.
International Search Report and Written Opinion for PCT Application No. PCT/US2017/051218 dated Nov. 17, 2018.
European Office Action application No. 16 837 957.6, dated May 29, 2019.
International Search Report and Written Opinion of the ISA, dated Jan. 8, 2019, for application No. PCT/US18/56916.
International Search Report and Written Opinion of the ISA, dated Feb. 14, 2019, for application No. PCT/US18/62665.
Japanese Office Action application No. 2018-506604, dated Jun. 4, 2019.
Chu, Hon Lung , “In-Vehicle Driver Detection Using Mobile Phone Sensors”, https://ece.duke.edu/sites/ece.duke.edu/files/ GWDD2011_Chu.pdf—2011 (Year: 2011).
Giuseppe, Guido , et al., “Using Smartphones as a Tool to Capture Road Traffic Attributes”, University of Calabria, Department of Civil Engineering, via P. Bucci, 87036—Rende (CS) Italy, Applied Mechanics and Materials, vol. 432 (2013, Trans Tech Publications, Switzerland, pp. 513-519.
Kalra, Nidhi , Analyzing Driving and Road Events via Smartphone, International Journal of Computer Applications (0975-8887), vol. 98-No. 12, Jul. 2014, pp. 5-9.
Mohan, Prashanth , et al., Nericell: Rich Monitoring of Road and Traffic Conditions using Mobile Smartphones. Microsoft Research India, SenSys '08, Nov. 5-7, 2008, Raleigh North Carolina, USA, 14 pages.
Short, Jeffrey , et al., “Identifying Autonomous Vehicle Technology Impacts on the Trucking Industry”, http://atri-online.org/wp-content/uploads/2016/11/ATRI-Autonomous-Vehicle-Impacts-11-2016.pdf (Year: 2016).
Tathagata, Das , et al., “PRISM: Platform for Remote Sensing using Smartphones”, In. Proc. Mobisys '10, Jun. 15-18, 2010, San Francisco, USA, pp. 63-76.
Walter, Debbie , et al., “Novel Environmental Features for Robust Multisensor Navigation”, Institute of Navigation GNSS+ 2013, pp. 1-6.
Related Publications (1)
Number Date Country
20210325187 A1 Oct 2021 US
Provisional Applications (1)
Number Date Country
62207461 Aug 2015 US
Continuations (3)
Number Date Country
Parent 16240183 Jan 2019 US
Child 17360769 US
Parent 15652558 Jul 2017 US
Child 16240183 US
Parent 15243513 Aug 2016 US
Child 15652558 US