Where a mobile computer device having a position sensor, such as a GPS sensor, and an accelerometer is configured to estimate a geographic position of the mobile computer device using the position sensor, the accuracy of such positions may be enhanced by correlating accelerations of the mobile computer device, as determined by the accelerometer, against the positions of known surface features within a vicinity of the estimated positions. If the observed accelerations are consistent with one of the known surface features, the location of the mobile computer device may be correlated with the location of the one of the known surface features.
|
1. A method comprising:
receiving, by a computer device, at least one signal from a global positioning system satellite at a first time, wherein the computer device comprises a global positioning system sensor and at least one computer processor;
determining information regarding a first estimated position of the computer device at the first time using the at least one computer processor based at least in part on the at least one signal received from the global positioning system satellite at the first time;
determining information regarding an acceleration of the computer device at the first time using the at least one computer processor;
determining information regarding an actual position of a first geographic constraint based at least in part on the information regarding the acceleration of the computer device at the first time using the at least one computer processor;
determining whether the information regarding the first estimated position of the computer device at the first time is consistent with the information regarding the actual position of the first geographic constraint; and
in response to determining that the information regarding the first estimated position of the computer device at the first time is consistent with the information regarding the actual position of the first geographic constraint,
storing an association of the actual position of the first geographic constraint and the computer device at the first time in at least one data store.
2. The method of
in response to determining that the information regarding the first estimated position of the computer device at the first time is not consistent with the information regarding the actual position of the first geographic constraint,
storing an association of the first estimated position of the computer device at the first time and the computer device at the first time in the at least one data store.
3. The method of
receiving at least one Wireless Fidelity network signal from a Wireless Fidelity network source; and
determining the first estimated position of the computer device at the first time based at least in part on the at least one Wireless Fidelity network signal.
4. The method of
5. The method of
determining a vertical component of the acceleration of the computer device at the first time; and
wherein determining the information regarding the actual position of the first geographic constraint based at least in part on the information regarding the acceleration of the computer device at the first time comprises:
identifying one of a plurality of geographic constraints associated with the vertical component of the acceleration of the computer device at the first time,
wherein the actual position of the first geographic constraint is an actual position of the one of the plurality of geographic constraints associated with the vertical component of the acceleration of the computer device at the first time.
6. The method of
7. The method of
wherein determining the information regarding the acceleration of the computer device at the first time further comprises:
determining the acceleration along at least one axis of orientation based at least in part on information obtained from the accelerometer at the first time.
8. The method of
wherein determining the information regarding the acceleration of the computer device at the first time further comprises:
determining the acceleration along at least one axis of orientation based at least in part on at least one of information obtained from the gyroscope at the first time or information obtained from the compass at the first time.
9. The method of
wherein determining the information regarding the acceleration of the computer device further comprises:
obtaining information from the accelerometer at the first time;
obtaining at least one of information from the gyroscope at the first time or information from the compass at the first time;
defining a fused output set of information comprising the information obtained from the accelerometer at the first time and the at least one of the information obtained from the gyroscope at the first time or the information, obtained from the compass at the first time; and
determining the acceleration along at least one axis of orientation based at least in part on the fused output set.
10. The method of
identifying a plurality of geographic constraints in a vicinity of the first estimated position of the computer device at the first time using the at least one computer processor, wherein the first geographic constraint is one of the plurality of geographic constraints; and
selecting one of the plurality of geographic constraints in the vicinity of the first estimated position of the computer device at the first time based at least in part on the information regarding the acceleration of the computer device at the first time using the at least one computer processor, wherein the first geographic constraint is the selected one of the geographic constraints.
11. The method of
estimating a velocity of the computer device based at least in part on the information regarding the acceleration of the computer device at the first time; and
determining information regarding a second estimated position of the computer device at a second time based at least in part on the information regarding the first estimated position of the computer device at the first time and the estimated velocity of the computer device.
12. The method of
determining information regarding an acceleration of the computer device at the second time using the at least one computer processor;
determining information regarding an actual position of a second geographic constraint based at least in part on the information regarding the acceleration of the computer device at the second time using the at least one computer processor;
determining whether the information regarding the second estimated position of the computer device at the second time is consistent with the information regarding the actual position of the second geographic constraint; and
in response to determining that the information regarding the second estimated position of the computer device at the second time is consistent with the information regarding the actual position of the second geographic constraint,
storing an association of the actual position of the second geographic constraint and the computer device at the second time in the at least one data store.
13. The method of
in response to determining that the information regarding the second estimated position of the computer device at the second time is not consistent with the information regarding the actual position of the second geographic constraint,
storing an association of the second estimated position of the computer device at the second time and the computer device at the second time in the at least one data store.
14. The method of
locating the at least one geographic constraint on a map of a vicinity of the first estimated position of the computer device at the first time based at least in part on the information regarding the acceleration of the computer device at the first time.
15. The method of
locating topographical data regarding a vicinity of the first estimated position of the computer device at the first time in at least one data store.
|
Many modern mobile computer devices, such as smartphones, tablet computers or other general or special purpose machines, include one or more components for determining information regarding a device's position, orientation, velocity or acceleration. For example, some such mobile computer devices may include Global Positioning System (or “GPS”) transceivers for determining positions using data received from one or more orbiting satellites, or cellular telephone equipment configured to estimate (e.g., triangulate) a position using signals received from one or more cellular telephone network towers or other network sources. Moreover, some such devices may also include compasses for determining directions, gyroscopes for determining orientations and accelerometers for sensing accelerations.
A GPS-enabled device may determine its position by interpreting signals that are received from multiple GPS satellites. A distance between the device and a GPS satellite may be determined by calculating a “time of flight” between the GPS satellite and the device for each such signal, which is assumed to travel at approximately the speed of light. Where three or more such signals are interpreted, the device may be determined to be located at a specific point on the planet to within a certain degree of accuracy or tolerance, commonly on the order of two to ten meters.
Occasionally, position information determined using GPS satellites and GPS-enabled equipment may be inaccurate, irrelevant or unavailable. For example, like any computer device, most GPS-enabled equipment requires an initialization period during which the GPS position information determined by such equipment is unreliable. Furthermore, where an environment includes many natural or artificial obstructions, such as tree limbs, office towers, mountains, walls or ceilings, the receipt of GPS signals by a GPS-enabled device may be delayed or otherwise interpreted as having arrived in an untimely manner. Moreover, even where GPS position information that is obtained or determined by a mobile computer device is within an acceptable degree of accuracy or tolerance (e.g., within two to ten meters), the information may be insufficient or unreliable for some purposes. For example, where an accurate position is desired in a dense, urban environment having a large number of individual locations (e.g., addresses or other points of interest) within a small, defined area, determining a precise location within the area may be of paramount importance.
As is set forth in greater detail below, the present disclosure is directed to enhancing the accuracy of geocoding processes or geocoded information using data captured from one or more on-board sensors associated with a mobile computer device. Specifically, the systems and methods disclosed herein are directed to enhancing the quality of a geocoding process by determining a geographic location of a mobile computer device to within a degree or level of accuracy, determining information or data regarding net accelerations, velocities or orientations of the mobile computer device, or of a user of the mobile computer device, or of a vehicle in which the mobile computer device is carried. Such information or data may be compared against real-world geographic information or constraints in order to confirm that the determined geographic location is correct, or to otherwise enhance the degree or level of accuracy of the determined geographic location. Additionally, the systems and methods disclosed herein are also directed to using such information or data to build a map or graph of surface features reflecting the topographical elements of an environment in which the mobile device, the user of the mobile device, or a vehicle in which the mobile device is carried, may be situated. Such surface features may be identified and mapped or graphed by an engine or module operating according to one or more machine learning algorithms or techniques, which may recognize where net accelerations, velocities or orientations of the mobile computer device may be consistent with a type or form of surface feature (e.g., slopes, surfaces or terrain aligned at any angle).
According to some embodiments of the present disclosure, information or data regarding accelerations, velocities or orientations may be obtained from an accelerometer, a gyroscope, a compass or any other like machine or component that may be associated with the mobile computer device, and may determine such accelerations, velocities or orientations in one or more directions in three-dimensional space, viz., along or about x-, y- or z-directions or axes. Moreover, information or data regarding accelerations, velocities or orientations may be processed in order to confirm a location of a mobile computer device, or to enhance the accuracy of a position of the mobile computer device that may be obtained using one or more geolocators, e.g., GPS sensors in communication with one or more GPS satellites, or one or more applications or modules for triangulating a position using cellular telephone network transmissions or other network signals.
Further, such information or data may be further processed in order to identify one or more surface features (e.g., natural terrain or artificial elements such as stairs or ramps) based on events or occurrences associated with the mobile computer device which relate to an environment in which the mobile computer devices is situated. Such information or data may be expressed in quantitative terms such as distances, elevations or angles, and also in qualitative terms such as “step up,” “step down,” “normal gait,” “elevator up,” and the like. Any number of inferences may be drawn or otherwise identified from such qualitative or quantitative information or data, which may be affiliated with one or more existing real-world geographic constraints such as pathways, stairways, hills, ramps, escalators or other features having corresponding variations in elevation and position, and may be correlated with two-dimensional or three-dimensional images (e.g., satellite or aerial photographs), topographical data, or information obtained from any other source. For example, where information or data regarding one or more surface features is identified based on net accelerations, velocities or orientations obtained from one or more sensors, intrinsic or extrinsic data may be identified and utilized to determine additional information regarding such surface features. Such intrinsic or extrinsic data may relate to specific surface features, e.g., unique topographical elements of terrain such as hills or artificial features such as ramps or stairs, that may be associated with a particular location, as well as surface features of a general kind or type, e.g., stairs constructed according to zoning requirements in existence in a given location or at a certain time, or ramps having slopes in compliance with one or more accessibility ordinances or statutes.
Referring to
Referring to
The net acceleration data 160 of
For example, the raw information or data may reflect localized variations in acceleration, velocity or position due to erratic or temporary eccentricities of the motion of the worker 110 (e.g., swings of arms or legs, twists of hips or heads, or temporary pauses or increases in speed), or noise or drift that may be associated with an accelerometer, a gyroscope or a compass over time. Additionally, the raw information or data may be subject to the effects of gravity. The raw information or data collectively obtained from all available sensors may be processed according to one or more high-pass or low-pass filters or any other processes or techniques in order to determine true, net accelerations, velocities or orientations of the worker 110, or of the handheld device 112, over time. Such net accelerations, velocities or orientations may be used to estimate a location of the worker 110 or of the handheld device 112, or to enhance the accuracy of a location identified by a geolocator or like means. Additionally, the net accelerations, velocities or orientations may be further utilized to identify one or more surface features in a vicinity of the worker 110 or of the handheld device 112 in accordance with the present disclosure.
As is shown in the plot 162, the net acceleration of the worker 110 along the x-axis is approximately zero until time t3, when the net acceleration temporarily drops to a negative value as the advancement of the worker 110 along the along the x-axis comes to a halt and never changes thereafter. As is also shown in the plot 164, the net acceleration of the worker 110 along the y-axis is substantially periodic until time t3, corresponding to the varying steps of the worker 110 along the surface feature 140. The net acceleration along the along the y-axis then increases as the worker 110 steps up onto the surface feature 142 and the surface feature 152, and continues substantially periodically until approximately time t5, when the worker 110 ascends each of the steps associated with the surface feature 150. As is further shown in the plot 166, the net acceleration of the worker 110 along the z-axis is substantially periodic until time t3, when the net acceleration increases as the worker 110 turns left (viz., in the positive z-axis direction) and begins to decrease at time t5 as the velocity of the worker 110 slows while the worker 110 ascends the steps of the surface feature 150.
Accordingly, as is shown in
For example, in evaluating acceleration data such as the net accelerations shown in the plots 162, 164, 166 of
Today, many modern mobile computer devices (e.g., smartphones, tablet computers or laptop computers) are able to detect and record one or more physical movements. For example, many smartphones, tablets or laptops include internal hardware components or software applications that may be utilized to determine the position, velocity, acceleration or orientation of such devices. Where a computing device includes a GPS receiver, an accelerometer, a gyroscope or a compass, the position, velocity, acceleration or orientation of the computing device may be determined and recorded using such components.
Mobile computer devices may determine their respective positions using various means or methods, such as a locating module that obtains a geocode or other data regarding a location of the mobile computer device at an associated level of accuracy or tolerance. Where a mobile computer device includes cellular telephonic equipment, such equipment may detect signals from one or more network sources, and use such signals to estimate, e.g., triangulate, a position of the mobile computer device. More commonly, such devices frequently include GPS sensors, microchips or other components that determine locations by interpreting signals from one or more GPS satellites. The GPS system comprises twenty-four satellites that circle the planet every twelve hours at an altitude of approximately eleven thousand nautical miles, and are maintained aloft by the United States Air Force. GPS-equipped computer devices typically operate by measuring the transit times of signals received from multiple satellites, which generally travel at the speed of light (viz., 186,000 miles per second, or 3.0×108 meters per second), and determining distances to the respective satellites based on the transit times. Using three or more such signals, an approximate position of a computer device may be determined to within a defined degree or level of accuracy. By some estimates, American GPS satellites may provide users with an accuracy level of approximately 7.8 meters (m), ninety-five percent of the time, anywhere around the planet.
Occasionally, however, some errors or inaccuracies may be encountered when determining positions using GPS systems. For example, propagation delays in the transmission of satellite signals may affect the speed of such signals through the ionosphere or troposphere. Additionally, any clocking delays may occasionally affect a determination of a distance between a device and a satellite, and a position of the device based on such a distance. Moreover, where GPS signals from one or more signals are blocked or impaired by vegetation or man-made structures, the accuracy of a position determined based on the interpretation of such signals may be called into question. Furthermore, in some applications, a position of a mobile computer device may be desired at a greater level of accuracy or precision than is currently available through the use of standard GPS systems and technology.
An accelerometer is an electromechanical device that is configured to generate a signal corresponding to accelerations, viz., changes in velocity over time, that are experienced by the device along one or more orthogonal axes or in one or more directions. By detecting accelerations, an accelerometer may be used to measure a variety of other data that may be related to accelerations, including velocities, reaction forces, inclinations, vibrations or the like. Accelerometers may be configured to determine accelerations in a single direction or along a single axis, or in multiple directions or along multiple axes (viz., x-, y- or z-accelerations), and to provide outputs regarding such accelerations in the form of scalars or vectors. For example, many mobile computer devices feature tri-axial accelerometers, which may determine accelerations in three axes or dimensions at once.
A gyroscope is a mechanical or electromechanical device that is configured to determine or maintain an orientation or velocity, and to measure angular motion relative to one or more inertial frames of reference. Gyroscopes are commonly used in inertial navigation systems and also in consumer electronics, and are commonly found in most forms of mobile devices such tablet computers, smartphones or the like. Traditionally, gyroscopes include rotors having fixed spin axes that are mounted to or within spin gimbals which may respond to torques with a form of motion called precession, in which the axis of rotation is reoriented in order to offset the torques. Such traditional gyroscopes, or more modern gyroscopes having one or more electronic components such as electrodes or capacitors, may be provided in connection with one or more devices or apparatuses for the purpose of determining one or more angular accelerations, velocities or orientations of such devices or apparatuses accordingly. A compass is a device that determines an orientation or a direction with regard to a fixed frame of reference associated with the surface of the Earth. Most magnetic compasses include magnetized needles that align themselves with the Earth's magnetic field, as defined by the orientation of the Earth's magnetic poles. Other forms of compasses, including gyrocompasses, may also be provided for the purpose of determining directions with regard to fixed frames of reference.
In accordance with the present disclosure, information or data obtained from any number or type of sensors associated with a mobile computer device may be aggregated and considered together in order to determine a net acceleration or net velocity of the mobile computer device, or of a user of the mobile computer device. According to one or more sensor fusion processes, information or data obtained as outputs from accelerometers, gyroscopes, compasses or other like sensors may be processed and combined into a fused output set that minimizes the expected errors associated with the individual outputs from such sensors. By aggregating information or data obtained from multiple sensors, the information or data of the fused output set may be expected to have a greater level of accuracy or reliability than information or data obtained from a single sensor. The net effect of the accelerations or velocities of the mobile computer device may be identified based on the fused output set, and utilized to determine a position of the mobile computer device, to enhance the accuracy of an estimated position of the mobile computer device, or to generate a map or graph of surface features in a vicinity of the mobile computer device.
Dead reckoning is a general term for a procedure by which a position of an object at a given time is predicted using a previously established position of the object (which is sometimes called a “fix”) and information regarding a kinematic state of the object. For example, where an initial position and a velocity of an object are known, a position of the object at a later time may be projected with respect to the initial position by integrating a function representative of the velocity (i.e., both speed and direction) over the elapsed time. Because dead reckoning relies on projections, one or more systematic and/or random errors may develop based on uncertainties of determined positions, velocities, or accelerations, and may be cumulative over time. For example, if the object were to begin moving from an accurately determined position, and the components of the velocity (e.g., speed and direction components) are determined with equal levels or degrees of accuracy, then a dead reckoning of the object would include areas of uncertainty which would grow or increase in equal proportion in all directions according to a technique known as “fix expansion.” A two-dimensional area of uncertainty would be expressed as a circle, an ellipse or a similar shape corresponding to the known errors associated with the position of the object in two dimensions over time, taking into account any errors associated with the position, the direction or the speed of travel of the object. Likewise, a three-dimensional volume of uncertainty may be expressed as a sphere or other similar shape corresponding to the known errors associated with the position of the object in three dimensions over time.
For example, when dead reckoning an object's travel from a fix, a circle corresponding to the errors associated with determining the fix would be drawn around the fix, and would be expanded in size based on the possible error or uncertainty factors. If one of the velocity components (e.g., a direction or a speed) is determined with a different level of accuracy than another velocity component, then the area of uncertainty would be drawn in the form of an ellipse or other applicable non-circular shape.
The systems and methods of the present disclosure are directed to acquiring information or data, e.g., topographical data or environmental feature information, from a variety of sensors associated with a mobile computer device, including but not limited to a smartphone, a tablet computer, or any other like machine. The information or data may then be processed and consumed for any function or application, such as to identify a position associated with the information or data, to enhance the accuracy of a dead reckoning system or a position estimated by such a system, or to generate a map or graph of surface features in a vicinity of the mobile computer device. Any information regarding the positions, the enhancements, or the maps or graphs of surface features may be maintained in on or more data stores and utilized for any relevant purpose.
According to one embodiment of the present disclosure, information or data regarding a position of a mobile computer device may be obtained by standard means, e.g., using a GPS sensor or by triangulating signals received from cellular towers or from other network sources (e.g., one or more wireless fidelity routers). Additionally, information or data regarding the accelerations, velocities or orientations of the mobile computer device may be obtained from one or more onboard sensors of the mobile device e.g., one or more accelerometers, gyroscopes, compasses or other like components, and mapped to one or more real-world geographic constraints. Where accelerations of the mobile computer device are observed as a worker or vehicle carries or operates the mobile computer device while traveling upon an area having one or more surface features, a location of worker or the vehicle may be determined by correlating the observed accelerations to the surface features within the area, which may have varying topographical characteristics.
For example, as is discussed above with regard to the system 100 of
The systems and methods disclosed herein provide a number of advantages over prior art position determining systems. For example, where a position is determined in a dense environment having a number of addresses or points of interest within an area of uncertainty associated with the position, some embodiments of the present disclosure may enhance the quality or accuracy of the position determination by mapping net acceleration data to surface features associated with the position, e.g., natural terrain or artificial elements in a vicinity of the position, and more precisely determining where, within the area of uncertainty, a mobile computer device is actually located. Moreover, where a mobile computer device includes not only a location provider (e.g., a GPS sensor) but also one or more sensors (e.g., an accelerometer, a gyroscope or a compass), the accuracy of a position obtained from the location provider may be enhanced wholly within the mobile computer device and without resort to any extrinsic sources or systems. Furthermore, by augmenting positions determined from a location provider, such as a GPS sensor, with net acceleration data, fewer instances of geocoding may be required in order to more accurately estimate a location of the mobile computer device. Additionally, a position may be geocoded from net acceleration data alone, thereby permitting a position to be determined even in the absence, failure or unavailability of an extrinsic positioning system, such as GPS or network signal triangulation. For example, a variety of sensors available on a mobile computer device may be used to determine accelerations, velocities and positions underground (e.g., while traveling through basements or mass transit systems), indoors (e.g., through large steel, concrete or other rigid structures) or behind walls, where signals are not easily transmitted to or received from such extrinsic systems.
The systems and methods disclosed herein may be used in any environment in which an enhanced determination of a position is desired. For example, where a worker delivers items, packages or parcels to a destination while traveling over a variety of surface features, one or more sensors may be used to capture information and data, and to derive net accelerations, during the worker's travels. Such information and data may augment position information obtained from a location provider, in order to determine a more precise path traveled by the worker. Such systems and methods are particularly useful where a location includes a number of possible destinations within a level of accuracy of a mobile computer device, or within an area of uncertainty defined by the position of the mobile computer device. For example, where multiple doors or entryways corresponding to unique, discrete destinations falling within an area of uncertainty associated with a position obtained using the mobile computer device includes, or where a location includes different destinations within the location, e.g., on different floors of a building, such as apartments or offices, net acceleration information or data determined using an accelerometer and one or more other sensors may be useful in pinpointing a specific position of the mobile computer device within the location. Finally, where real-world cartographic information regarding an area is unavailable, acceleration information or data obtained using an accelerometer and one or more other sensors may be helpful in identifying and mapping surface features within the area.
Referring to
The marketplace 210 may be any entity or individual that wishes to make items from a variety of sources (e.g., vendors, manufacturers, merchants or sellers) available for download, purchase, rent, lease or borrowing by customers using a networked computer infrastructure, including one or more physical computer servers 212 and databases 214 for hosting a web site 216. The marketplace 210 may be physically or virtually associated with one or more storage or distribution facilities, such as the fulfillment center 220. The web site 216 may be implemented using the one or more servers 212, which connect or otherwise communicate with the one or more databases 214 as well as the network 270, as indicated by line 218, through the sending and receiving of digital data. Moreover, the database 214 may include any type of information regarding items that have been made available for sale through the marketplace 210, or ordered by customers, such as the customer 260, from the marketplace 210.
The fulfillment center 220 may be any facility that is adapted to receive, store, process and/or distribute items. As is shown in
The fulfillment center 220 may operate one or more order processing and/or communication systems using a computing device such as the desktop computer 222 and/or software applications having one or more user interfaces 224 (e.g., a browser), or through one or more other computing devices or machines that may be connected to the network 270, as is indicated by line 228, in order to transmit or receive information in the form of digital or analog data, or for any other purpose. The desktop computer 222 may also operate or provide access to one or more reporting systems for receiving or displaying information or data regarding workflow operations, and may provide one or more interfaces, such as the user interface 224, for receiving interactions (e.g., text, numeric entries or selections) from one or more operators, users or workers in response to such information or data. The desktop computer 222 may be a general purpose device or machine, or a dedicated device or machine that features any form of input and/or output peripherals such as scanners, readers, keyboards, keypads, touchscreens or like devices, and may further operate or provide access to one or more engines for analyzing the information or data regarding the workflow operations, or the interactions received from the one or more operators, users or workers.
The receiving station 221 may include any apparatuses that may be required in order to receive shipments of items at the fulfillment center 220 from one or more sources and/or through one or more channels, including but not limited to docks, lifts, cranes, jacks, belts or other conveying apparatuses for obtaining items and/or shipments of items from carriers such as cars, trucks, trailers, freight cars, container ships or cargo aircraft (e.g., manned aircraft or unmanned aircraft, such as drones), and preparing such items for storage or distribution to customers. The storage area 223 may include one or more predefined two-dimensional or three-dimensional spaces for accommodating items and/or containers of such items, such as aisles, rows, bays, shelves, slots, bins, racks, tiers, bars, hooks, cubbies or other like storage means, or any other appropriate regions or stations. The distribution station 225 may include one or more regions or stations where items that have been retrieved from a designated storage area may be evaluated, prepared and packed for delivery from the fulfillment center 220 to addresses, locations or destinations specified by customers, also by way of carriers such as cars, trucks, trailers, freight cars, container ships or cargo aircraft (e.g., manned aircraft or unmanned aircraft, such as drones). Those of ordinary skill in the pertinent art will recognize that shipments of items arriving at the receiving station 221 may be processed, and the items placed into storage within the storage areas 223 or, alternatively, transferred directly to the distribution station 225, or “cross-docked,” for prompt delivery to one or more customers.
The fulfillment center 220 may further include one or more control systems that may generate instructions for conducting operations at one or more of the receiving station 221, the storage area 223 or the distribution station 225. Such control systems may be associated with the desktop computer 222 or with one or more other computing devices or machines, and may communicate with the receiving station 221, the storage area 223 or the distribution station 225 within the fulfillment center 220 by any known wired or wireless means, or with the marketplace 210, the truck 230, the worker 240 or the customer 260 over the network 270, as indicated by line 228, through the sending and receiving of digital data.
Additionally, the fulfillment center 220 may include one or more systems or devices (not shown in
The truck 230 may be any motorized or non-motorized carrier or vehicle for transporting the worker 240 and one or more items, which may be prepared, packed and shipped in any type or form of container. For example, the truck 230 may be any type or form of light truck, medium truck or heavy truck, such as a platform truck, a flatbed truck, a tractor and/or trailer, as well as any form of van. Alternatively, those of ordinary skill in the pertinent arts will recognize that any other form or means of transportation may perform the functions of the truck 230 in accordance with the present disclosure, including but not limited to cars, trailers, freight cars, container ships or cargo aircraft (e.g., manned aircraft or unmanned aircraft, such as drones).
The worker 240 may handle or transport items within the fulfillment center 220, prepare such items for delivery to a customer, such as the customer 260, and deliver such items to the customer. For example, the worker 240 may retrieve items from a storage means within the storage area 223, transport the items to the distribution station 225, and prepare the items for delivery to one or more customers. Alternatively, the worker 240 may also transport, or “cross-dock,” items directly from the receiving station 221 to the distribution station 225. Furthermore, the worker 240 may cause the placement of the prepared items onto a vehicle for delivery, such as the truck 230, and operate the truck 230 when causing a delivery of the items to a customer, such as the customer 260.
When the worker 240 is transporting items within the fulfillment center 220, preparing such items for delivery to a customer, or delivering the items to the customer, the worker 240 may operate one or more handheld devices 250, which may be a device that is specifically programmed or adapted for such purposes, or a general purpose device such a personal digital assistant, a digital media player, a smartphone, a tablet computer or a laptop computer, as well as a wearable computer device such as a pair of augmented reality glasses or a wristwatch, and may include any form of input and/or output peripherals such as scanners, readers, keyboards, keypads, touchscreens or pointing devices. For example, the worker 240 may confirm his or her retrieval of an item using the handheld device 250, as well as his or her placement of the item onto the truck 230, his or her delivery of the item to a destination using the truck 230, his or her arrival at the destination with the item, his or her retrieval of the item from the truck 230, and a completed delivery of the item to the destination at any time using the handheld device 250.
As is shown in
The handheld device 250 may be further configured to capture, record and/or analyze information or data regarding the positions, velocities, accelerations or orientations of the handheld device 250, and to analyze such data or information by one or more means, e.g., by aggregating or summing such data or information to form one or more qualitative or quantitative metrics of the movement of the handheld device 250. For example, a net vector indicative of any and all relevant movements of the handheld device 250, including but not limited to physical positions, velocities, accelerations or orientations of the handheld device 250, may be derived. Additionally, coefficients or scalars indicative of the relative movements of the handheld device 250 (e.g., a position, a typing speed or an angular orientation), or activity of the worker 240 (e.g., driving, walking, running on any surface features) may also be defined.
The customer 260 may be any entity or individual that wishes to download, purchase, rent, lease, borrow or otherwise obtain items (which may include goods, products, services or information of any type or form) from the marketplace 210. The customer 260 may utilize one or more computing devices, such as a smartphone 262 or any other like machine that may operate or access one or more software applications, such as a web browser (not shown) or a shopping application 264, and may be connected to or otherwise communicate with the marketplace 210, the fulfillment center 220, the truck 230 or the worker 240 through the network 270, as indicated by line 268, by the transmission and receipt of digital data. Moreover, the customer 260 may also receive deliveries or shipments of one or items from facilities maintained by or on behalf of the marketplace 210, such as the fulfillment center 220, by way of the truck 230 or other transportation means (e.g., cars, trailers, freight cars, container ships or cargo aircraft, including manned aircraft or unmanned aircraft, such as drones).
The computers, servers, devices and the like described herein have the necessary electronics, software, memory, storage, databases, firmware, logic/state machines, microprocessors, communication links, displays or other visual or audio user interfaces, printing devices, and any other input/output interfaces to provide any of the functions or services described herein and/or achieve the results described herein. Also, those of ordinary skill in the pertinent art will recognize that users of such computers, servers, devices and the like may operate a keyboard, keypad, mouse, stylus, touch screen, or other device (not shown) or method to interact with the computers, servers, devices and the like, or to “select” an item, link, node, hub or any other aspect of the present disclosure.
Those of ordinary skill in the pertinent arts will understand that process steps described herein as being performed by a “marketplace,” a “fulfillment center,” a “worker” or a “customer,” or like terms, may be automated steps performed by their respective computer systems, or implemented within software modules (or computer programs) executed by one or more general purpose computers. Moreover, process steps described as being performed by a “marketplace,” a “fulfillment center,” a “worker” or a “customer” may be typically performed by a human operator, but could, alternatively, be performed by an automated agent.
The marketplace 210, the fulfillment center 220, the truck 230, the worker 240 and/or the customer 260 may use any web-enabled or Internet applications or features, or any other client-server applications or features including electronic mail (or E-mail), or other messaging techniques, to connect to the network 270 or to communicate with one another, such as through short or multimedia messaging service (SMS or MMS) text messages. For example, the fulfillment center 220 and/or the desktop computer 222 may be adapted to transmit information or data in the form of synchronous or asynchronous messages to the server 212, the handheld device 250, the smartphone 262 or any other computer device in real time or in near-real time, or in one or more offline processes, via the network 270. Those of ordinary skill in the pertinent art would recognize that the marketplace 210, the fulfillment center 220, the truck 230, the worker 240 or the customer 260 may operate any of a number of computing devices that are capable of communicating over the network, including but not limited to set-top boxes, personal digital assistants, digital media players, web pads, laptop computers, desktop computers, electronic book readers, and the like. The protocols and components for providing communication between such devices are well known to those skilled in the art of computer communications and need not be described in more detail herein.
The data and/or computer executable instructions, programs, firmware, software and the like (also referred to herein as “computer executable” components) described herein may be stored on a computer-readable medium that is within or accessible by computers or computer components such as the server 212, the desktop computer 222, the handheld device 250 or the smartphone 262, or any other computers or control systems utilized by the marketplace 210, the fulfillment center 220, the truck 230, the worker 240 or the customer 260 and having sequences of instructions which, when executed by a processor (e.g., a central processing unit, or “CPU”), cause the processor to perform all or a portion of the functions, services and/or methods described herein. Such computer executable instructions, programs, software and the like may be loaded into the memory of one or more computers using a drive mechanism associated with the computer readable medium, such as a floppy drive, CD-ROM drive, DVD-ROM drive, network interface, or the like, or via external connections.
Some embodiments of the systems and methods of the present disclosure may also be provided as a computer executable program product including a non-transitory machine-readable storage medium having stored thereon instructions (in compressed or uncompressed form) that may be used to program a computer (or other electronic device) to perform processes or methods described herein. The machine-readable storage medium may include, but is not limited to, hard drives, floppy diskettes, optical disks, CD-ROMs, DVDs, ROMs, RAMs, erasable programmable ROMs (“EPROM”), electrically erasable programmable ROMs (“EEPROM”), flash memory, magnetic or optical cards, solid-state memory devices, or other types of media/machine-readable medium that may be suitable for storing electronic instructions. Further, embodiments may also be provided as a computer executable program product that includes a transitory machine-readable signal (in compressed or uncompressed form). Examples of machine-readable signals, whether modulated using a carrier or not, may include, but are not limited to, signals that a computer system or machine hosting or running a computer program can be configured to access, or including signals that may be downloaded through the Internet or other networks.
As is discussed above, the systems and methods of the present disclosure are directed to enhancing the accuracy of geocoding, viz., or identifying associated geographic coordinates or other location information from other geographic data, or any other estimation of a location or position, through the use of accelerometers and other sensors. Specifically, information regarding a position of a mobile computer device that is obtained from a location provider associated with the mobile computer device having a degree or level of error or tolerance may be augmented with acceleration information or data obtained from one or more sensors with regard to one or multiple orthogonal axes, and the information or data may be mapped against one or more surface features (such as pathways, stairways, hills, ramps, escalators or other features having corresponding variations in elevation and position) in a vicinity of the mobile computer device in order to narrow the error or tolerance associated with the information regarding the position. Referring to
At box 310, attributes of a portable computer device are monitored during the performance of an activity using one or more various onboard sensors. For example, where the worker 110 of
At box 320, net accelerations of a user of the portable computer device are determined in at least one dimension during the activity based on the composite information. For example, where a portable computer device includes an on-board accelerometer, gyroscope or compass, e.g., the accelerometer 256, the gyroscope 257 or the compass 258 of the portable device 250 of
At box 330, information regarding environmental features and surface contours in a vicinity of an estimated geographic position of the portable computer device is identified. In this regard, a database or other record of topographical or digital terrain data that includes information regarding elevations of various surface features in a vicinity of the portable computer device may be identified and accessed. At box 340, the net accelerations determined at box 320 may be mapped to the environmental features and surface contour information in the vicinity of the estimated geographic position of the portable computer device. Where such environmental features or surface contours indicate varying changes of elevation or position in the area of the estimated geographic position of the handheld device, the net accelerations determined at box 320 may be compared to such information in order to determine whether the net accelerations are consistent with the features or contours.
For example, according to one embodiment, where the net accelerations determined at box 320 indicate a substantially constant sinusoidal pattern of vertical accelerations consistent with a walking gait and no net change in vertical velocity (e.g., in a y-direction), the portable computer device may be deemed to be traveling on a substantially flat surface. Where the accelerations indicate a net increase in vertical velocity, however, the portable computer device may be deemed to have changed its direction or speed in an upward direction, such as by proceeding from a substantially flat surface into an upwardly sloped or upwardly configured surface, e.g., a ramp or set of stairs. Where the accelerations indicate a net increase or decrease in horizontal velocities, the portable computer device may be deemed to have changed its direction or speed in a horizontal direction (e.g., in an x-direction or a z-direction).
At box 350, the portable computer device determines whether the net accelerations are consistent with the expected accelerations for the environmental features and surface contour information in the vicinity of the estimated geographic position. For example, if the estimated geographic position indicates that a ramp or set of stairs is nearby, and the net accelerations mapped at box 340 are consistent with travel upon a ramp or set of stairs, then the mapped accelerations are deemed to be consistent with the estimated geographic position, and the process advances to box 360, where the estimated geographic position is confirmed as the actual geographic position. A comparison of observed net accelerations to expected accelerations may consider any relevant extrinsic or intrinsic information or data, alone or in combination. For example, where net accelerations imply both a set number of steps (e.g., a sinusoidal pattern having a fixed number of peaks) and also a net change in elevation or a net distance traveled, the combination of such information may uniquely identify a location in a manner that the number of steps, the net change in elevation or the net distance traveled alone would not. Conversely, if the estimated geographic position indicates a ramp or set of stairs, and the mapped accelerations are deemed to be consistent with travel upon a substantially flat surface, then the mapped accelerations are deemed to be inconsistent with the estimated geographic position. Thus, the process advances to box 355, where the estimated geographic position is modified to correspond with the surface contour information to which the accelerations are mapped, and the process ends.
Accordingly, as is set forth above, the systems and methods of the present disclosure may be used to determine confirm a location of a mobile computer device, or to narrow an area of uncertainty associated with such a position, by comparing observed accelerations to known surface features in a vicinity, mapping the observed accelerations to the known surface features, and correlating the location with the mapped accelerations. Moreover, where a sufficiently large set of data regarding motion of a mobile computer device and detailed information regarding an environment or surface contours in which such motion was observed are available, a sufficiently precise geocode or other relevant positioning information may be derived even where a geolocator or location provider such as a GPS sensor or a network triangulation module is unavailable (e.g., indoors or underground).
One example of an application in which the systems and methods of the present disclosure, such as the process embodied in the flow chart 300 of
As is discussed above, positions of mobile computer devices that are determined using location providers such as GPS sensors or network triangulations are typically accurate to within a defined level of error or tolerance. Referring to
As is also discussed above, the systems and methods of the present disclosure may enhance the accuracy of positions estimated using standard location providers (e.g., GPS or network triangulations) or by any other means (e.g., an expected or predicted location, such as an anticipated street address where a mobile computer device is believed to be located) by determining accelerations experienced by a mobile computer device, and mapping such accelerations to known surface features in a vicinity of the estimated positions. In this regard, the accuracy of a position, such as the areas of uncertainty A0, A1, A2, A3 of
Similarly, referring to
Accordingly, the systems and methods of the present disclosure may enhance the accuracy of positions of mobile computer devices determined using standard location providers by determining net accelerations associated with such devices and mapping such accelerations against real-world constraints within a vicinity of such positions. By mapping net accelerations to real-world constraints, a more precise position within an area of uncertainty may be determined, such as by identifying which of the surface features 452, 454, 456 shown in
As is also discussed above, the systems and methods of the present disclosure may improve the accuracy of dead reckoned positions determined based on locations obtained from GPS sensors, triangulations of network signals or other location providers, either on a one-time or iterative basis. Referring to
At box 525, a value of a loop iterator variable i is set at 1, and at box 520, data regarding motion of the mobile computer device may be monitored using on-board sensors during the performance of an evolution in an area. For example, a smartphone's accelerometer may determine variations in acceleration in x-, y- or z-directions or along x-, y- or z-axes as a user of the smartphone performs one or more tasks in a specific area, while the smartphone's gyroscope may determine the orientations of the accelerometer about the x-, y- or z-axes, and the compass may determine a direction associated with motions executed during the performance of the tasks. At box 530, a dead reckoned position of the mobile computer device during the performance of the evolution is projected at time ti. For example, where a position and a velocity of the mobile computer device are able to be estimated, the dead reckoned position of the mobile computer device may be projected to within a certain degree of accuracy or tolerance according to one or more dead reckoning systems. The dead reckoned position may be determined in a probabilistic manner, taking into account one or more possible positions, and selecting a most appropriate or most probable position on any relevant bases.
At box 540, surface features in an area corresponding to the data regarding the motion that were observed during the performance of the evolution at time ti are identified. For example, any hills, slopes, ramps, structures or other natural terrain or artificial features in a vicinity of the accelerations may be located using one or more sets of data or information such as photographs, charts or tables including topographical data, and compared to the accelerations observed at time ti. At box 550, a “re-fix” of the dead reckoned position of the mobile computer device is determined according to the surface features corresponding with the data regarding the motion of the mobile computer device that was observed at time ti. For example, the dead reckoned position may be relocated, or the area of uncertainty narrowed, where net accelerations observed may be correlated with one or more surface features, thereby confirming a specific location of the mobile computer device based on such net accelerations.
If the surface features correspond to the dead reckoned position, or after repositioning the dead reckoned position based on the surface features, the process advances to box 560, where a user may be prompted to indicate whether the projection of a dead reckoned position of the mobile computer device is to be continued. If the projections are to continue, then the process advances to box 570, where the value of a loop iterator variable i is incrementally advanced by 1, before returning to box 520, where data regarding the motion of the mobile computer device is monitored using on-board sensors during the performance of an evolution in the area at time ti. If further projections are no longer desired, the process ends.
Referring to
As is discussed above, the systems and methods of the present disclosure may enhance the accuracy of a dead reckoned position by identifying any available information or data regarding net accelerations of a mobile computer device, or a user of the mobile computer device, in a vicinity of one or more environmental features or surface contours in a vicinity of the computer device. Where the net accelerations may be associated with one or more of the features or contours, an area of uncertainty associated with a dead reckoned position may be reduced by correlating the dead reckoned position with one or more of the respective features or contours. Referring to
As is shown in
Moreover, the systems and methods of the present disclosure may be further utilized to construct virtual maps of surfaces of regions based at least in part on mapped net acceleration data. For example, where a mobile computer device having a variety of on-board sensors such as accelerometers, gyroscopes or compasses observes net accelerations that are consistent with travel over flat surfaces for distances or periods of time, the mobile computer device may provide information regarding such accelerations and/or any other relevant intrinsic or extrinsic data to an identification engine or module that may project one or more surface features in a vicinity of the mobile computer device. For example, a surface feature identification engine may utilize such net accelerations, and any other relevant intrinsic or extrinsic data, to generate a map or graph indicative of the flat surfaces over the distances or for the periods of time according to one or more machine learning techniques. According to some embodiments, the surface features represented in the map or graph may be correlated with an area of uncertainty of a position obtained from a location provider (e.g., a GPS sensor) of the mobile computer device. Similarly, where the mobile computer device observes accelerations that are consistent with travel over sloped surfaces (e.g., travel up or down ramps) or stepped surfaces (e.g., up or down stairs), or across other surface features including not only natural terrain but also artificial features for predetermined distances or times, the identification engine may generate a map indicative of such surface features over such distances or times, which may be correlated with one or more areas of uncertainty of positions obtained from a location provider.
Referring to
At box 730, net accelerations of the mobile computer device may be defined based on the captured data, which may be combined or aggregated according to one or more sensor fusion algorithms or according to any relevant technique. For example, referring again to
At box 750, the captured data and the net accelerations may be interpreted using the surface feature identification engine. For example, the captured data may be processed to filter out any noise or to account for any drift associated with one or more sensors from which the data was captured, or to remove the effects of gravity therefrom, and to recognize one or more characteristics therefrom. At box 760, a map of surface features is defined based on the interpretations of the captured data and the net accelerations. For example, the accelerations, velocities or orientations of the mobile computer device at given times may be interpreted based on the net accelerations or captured data, and the motion of the device may be defined by line segments, planar segments or any other positional representations of features of the surfaces upon which a user of the mobile computer device traveled at such times. Such features may indicate flat surfaces or sloped surfaces, as well as one or more discontinuities (e.g., stairs, cliffs, breaks or gaps) of such surfaces.
At box 770, the map of the surface features may be stored in at least one data store, and may be used for any suitable purpose. For example, the map may act as a forensic record of the travels of a user of the mobile computer device at the time of its derivation or, alternatively, may be used as a guide for future travels of users of the mobile computer device, or of other mobile computer devices.
The generation of a map or a graph of surface features in accordance with the present disclosure may be shown in
Referring to
Referring to
As is shown in
Referring to
Thus, the surface features 850 of the area shown in
Although the disclosure has been described herein using exemplary techniques, components, and/or processes for implementing the present disclosure, it should be understood by those skilled in the art that other techniques, components, and/or processes or other combinations and sequences of the techniques, components, and/or processes described herein may be used or performed that achieve the same function(s) and/or result(s) described herein and which are included within the scope of the present disclosure. For example, although some of embodiments disclosed herein show the travel of users of mobile computer devices outdoors and on foot, the systems and methods of the present disclosure are not so limited, and may be used within one or more vehicles or indoors, where quality or strength of communication between a GPS sensor and one or more GPS satellites may be limited. In one such embodiment, the systems and methods of the present disclosure may be used in a subterranean environment (e.g., within a subway system or other underground network), where no connectivity between a mobile computer device and a location provider, such as a GPS network or cellular telephone network, is available.
Moreover, although some of the embodiments disclosed herein show the use of handheld computer device by one or more human users, the systems and methods of the present disclosure are not so limited. For example, the systems and methods disclosed herein may be provided in connection with the operation of one or more vehicles and used to estimate or confirm positions of such vehicles based on data obtained from one or more sensors, or to map or graph surface features (e.g., potholes or other discontinuities in one or more roads or paths) traveled upon by such vehicles. Likewise, although some of the embodiments disclosed herein reference the identification of an estimated position of a computer device through the use of a hardware component such as a GPS sensor or a software component such as a triangulation module, the systems and methods disclosed herein are not so limited. Rather, an estimated position may be identified by any means, such an anticipated address or location where the mobile computer device is expected to be located, or may be located, and the estimated position may be verified in accordance with one or more of the systems and methods disclosed herein.
It should be understood that, unless otherwise explicitly or implicitly indicated herein, any of the features, characteristics, alternatives or modifications described regarding a particular embodiment herein may also be applied, used, or incorporated with any other embodiment described herein, and that the drawings and detailed description of the present disclosure are intended to cover all modifications, equivalents and alternatives to the various embodiments as defined by the appended claims. Moreover, with respect to the one or more methods or processes of the present disclosure described herein, including but not limited to the flow charts shown in
Conditional language, such as, among others, “can,” “could,” “might,” or “may,” unless specifically stated otherwise, or otherwise understood within the context as used, is generally intended to convey in a permissive manner that certain embodiments could include, or have the potential to include, but do not mandate or require, certain features, elements and/or boxes or steps. In a similar manner, terms such as “include,” “including” and “includes are generally intended to mean “including, but not limited to.” Thus, such conditional language is not generally intended to imply that features, elements and/or boxes or steps are in any way required for one or more embodiments or that one or more embodiments necessarily include logic for deciding, with or without user input or prompting, whether these features, elements and/or boxes or steps are included or are to be performed in any particular embodiment.
Although the invention has been described and illustrated with respect to exemplary embodiments thereof, the foregoing and various other additions and omissions may be made therein and thereto without departing from the spirit and scope of the present disclosure.
Patent | Priority | Assignee | Title |
10112801, | Aug 05 2014 | Elevator inspection apparatus with separate computing device and sensors | |
10165412, | May 22 2014 | Sony Corporation | Information processing device and information processing method |
10582341, | Apr 24 2014 | AT&T MOBILITY II LLC | Facilitating estimation of mobile device presence inside a defined region |
10830606, | Feb 09 2015 | Invensense, Inc. | System and method for detecting non-meaningful motion |
10877127, | Sep 24 2018 | Science Applications International Corporation | System and method for dismounted assured position, navigation and timing (DAPNT) |
10937263, | Sep 27 2018 | Amazon Technologies, Inc | Smart credentials for protecting personal information |
10976742, | Mar 14 2016 | YANMAR POWER TECHNOLOGY CO , LTD | Ship handling device |
11127039, | Aug 01 2014 | Oracle International Corporation | Delivering geo-context information to a mobile device based on predicted mobile device locations |
11280874, | Sep 24 2018 | Science Applications International Corporation | System and method for dismounted assured position, navigation and timing (DAPNT) |
Patent | Priority | Assignee | Title |
5301114, | Jun 11 1992 | AlliedSignal Inc | Inertial navigation system including self-contained performance validating arrangement |
7409291, | Feb 26 2004 | STMICROELECTRONICS INTERNATIONAL N V | Device for automatic detection of states of motion and rest, and portable electronic apparatus incorporating it |
8321128, | May 14 2007 | Thinkware Systems Corporation | Method for correcting map matching and navigation system implementing the method |
20080059068, | |||
20090005985, | |||
20090247186, | |||
20100057360, | |||
20100121573, | |||
20100250134, | |||
20100312461, | |||
20110066377, | |||
20110071759, | |||
20110112764, | |||
20110125403, | |||
20110208496, | |||
20130214925, | |||
20140095009, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Mar 31 2014 | Amazon Technologies, Inc. | (assignment on the face of the patent) | / | |||
Apr 25 2014 | BUETHER, JOHN NICHOLAS | Amazon Technologies, Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 033311 | /0809 |
Date | Maintenance Fee Events |
Jun 29 2020 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Jun 27 2024 | M1552: Payment of Maintenance Fee, 8th Year, Large Entity. |
Date | Maintenance Schedule |
Dec 27 2019 | 4 years fee payment window open |
Jun 27 2020 | 6 months grace period start (w surcharge) |
Dec 27 2020 | patent expiry (for year 4) |
Dec 27 2022 | 2 years to revive unintentionally abandoned end. (for year 4) |
Dec 27 2023 | 8 years fee payment window open |
Jun 27 2024 | 6 months grace period start (w surcharge) |
Dec 27 2024 | patent expiry (for year 8) |
Dec 27 2026 | 2 years to revive unintentionally abandoned end. (for year 8) |
Dec 27 2027 | 12 years fee payment window open |
Jun 27 2028 | 6 months grace period start (w surcharge) |
Dec 27 2028 | patent expiry (for year 12) |
Dec 27 2030 | 2 years to revive unintentionally abandoned end. (for year 12) |