Not Applicable.
I. Field of the Invention
This disclosure relates generally to apparatus and methods for location estimation. More particularly, the disclosure relates to providing calibrated sensor measurements in a building or other structure when satellite navigation systems are unavailable or inadequate.
II. Background
Today, mobile devices having an ability to provide position estimates while in open areas are ubiquitous. In rural environment with a view of four or more positioning satellites, a mobile device acquires satellite signals and computes a position estimate based solely on these satellite signals. When in an urban environment or indoors, however, sufficient satellite signals are usually unobtainable. When adequate satellite signals are inaccessible, mobile devices often use signals from a cellular network to obtain a rough position estimate (e.g., via Cell IDs, trilateration, or triangulation). To improve position estimates when satellite and cellular signals are insufficient, a mobile device may use inertial sensors and dead reckoning. Over a long period, however, inertial sensors and conventional dead reckoning accumulate errors resulting in unreliable position estimates.
Disclosed is an apparatus and method for providing a navigational device that uses exterior walls as a reference, a navigational device that calibrated sensor measurements, and a navigation device that performs wall matching.
According to some aspects, disclosed is a method of navigation in a mobile device using a reference wall, the method comprising: determining a reference angle (θREF) of the reference wall; capturing, with a camera in the mobile device, a local image containing a horizontal feature; processing the local image to determine a horizontal feature angle (θHF), wherein the horizontal feature angle (θHF) measures an angle from a current orientation of the mobile device to the horizontal feature; selecting a wall angle, of the horizontal feature, equal to an integer multiple of 90° from the reference angle (θREF); and determining an angle of the current orientation of the mobile device based on a combination of the horizontal feature angle (θHF) and the wall angle.
According to some aspects, disclosed is a method of calibrating an inertial sensor in a mobile device, the method comprising: capturing a first image, at a first time from the mobile device in a first orientation, wherein the first image contains a horizontal feature; determining a first horizontal feature angle (θHF
According to some aspects, disclosed is a method of navigation in a mobile device using a reference wall, the method comprising: determining a reference angle (θREF) of the reference wall; determining an estimated direction of motion of the mobile device based on inertial sensor measurements; selecting a wall angle, closest to the estimated direction, equal to an integer multiple of 90° from the reference angle (θREF); and determining a direction of motion of the mobile device based on the wall angle.
According to some aspects, disclosed is a method of navigation in a mobile device using a reference wall, the method comprising: capturing, with a camera in the mobile device, a local image containing a horizontal feature and the reference wall; determining a reference angle (θREF) of the reference wall; processing the local image to determine a horizontal feature angle (θHF), wherein the horizontal feature angle (θHF) measures an angle from a current orientation of the mobile device to the horizontal feature; and determining an angle of the current orientation of the mobile device based on a combination of the horizontal feature angle (θHF) and the reference angle (θREF).
According to some aspects, disclosed is a method of providing calibrated inertial sensor measurements, the method comprising: determining a first reference angle (θREF
According to some aspects, disclosed is a mobile device for navigation using a reference wall, the mobile device comprising: a camera; an inertial sensor; and a processor and memory comprising code for: determining a reference angle (θREF) of the reference wall; capturing, with the camera in the mobile device, a local image containing a horizontal feature; processing the local image to determine a horizontal feature angle (θHF), wherein the horizontal feature angle (θHF) measures an angle from a current orientation of the mobile device to the horizontal feature; selecting a wall angle, of the horizontal feature, equal to an integer multiple of 90° from the reference angle (θREF); and determining an angle of the current orientation of the mobile device based on a combination of the horizontal feature angle (θHF) and the wall angle.
According to some aspects, disclosed is a mobile device for navigation using a reference wall, the mobile device comprising: means for determining a reference angle (θREF) of the reference wall; means for capturing a local image containing a horizontal feature; means for processing the local image to determine a horizontal feature angle (θHF), wherein the horizontal feature angle (θHF) measures an angle from a current orientation of the mobile device to the horizontal feature; means for selecting a wall angle, of the horizontal feature, equal to an integer multiple of 90° from the reference angle (θREF); and means for determining an angle of the current orientation of the mobile device based on a combination of the horizontal feature angle (θHF) and the wall angle.
According to some aspects, disclosed is a non-transient computer-readable storage medium including program code stored thereon, for navigation using a reference wall, comprising program code for: determining a reference angle (θREF) of the reference wall; receiving, from a camera in the mobile device, a local image containing a horizontal feature; processing the local image to determine a horizontal feature angle (θHF), wherein the horizontal feature angle (θHF) measures an angle from a current orientation of the mobile device to the horizontal feature; selecting a wall angle, of the horizontal feature, equal to an integer multiple of 90° from the reference angle (θREF); and determining an angle of the current orientation of the mobile device based on a combination of the horizontal feature angle (θHF) and the wall angle.
According to some aspects, disclosed is a mobile device for navigation using wall matching with a horizontal feature to estimate motion, the mobile device comprising: a camera; an inertial sensor; and a processor and memory comprising code for: capturing, with the camera in the mobile device, a local image containing the horizontal feature; processing the local image to determine a horizontal feature angle (θHF), wherein the horizontal feature angle (θHF) is an angle from a current orientation of the mobile device to the horizontal feature; and estimating a direction of motion of the mobile device, based on the horizontal feature angle (θHF), as parallel to a wall angle of the horizontal feature.
According to some aspects, disclosed is a mobile device for navigation using wall matching with a horizontal feature to estimate motion, the mobile device comprising: means for capturing a local image containing the horizontal feature; means for processing the local image to determine a horizontal feature angle (θHF), wherein the horizontal feature angle (θHF) is an angle from a current orientation of the mobile device to the horizontal feature; and means for estimating a direction of motion of the mobile device, based on the horizontal feature angle (θHF), as parallel to a wall angle of the horizontal feature.
According to some aspects, disclosed is a non-transient computer-readable storage medium including program code stored thereon, navigation using wall matching with a horizontal feature to estimate motion, comprising program code for: receiving, from a camera in the mobile device, a local image containing the horizontal feature; processing the local image to determine a horizontal feature angle (θHF), wherein the horizontal feature angle (θHF) is an angle from a current orientation of the mobile device to the horizontal feature; and estimating a direction of motion of the mobile device, based on the horizontal feature angle (θHF), as parallel to a wall angle of the horizontal feature.
According to some aspects, disclosed is a mobile device for calibrating an inertial sensor, the mobile device comprising: a camera; the inertial sensor; and a processor and memory comprising code for: capturing a first image, at a first time from the mobile device in a first orientation, wherein the first image contains a horizontal feature; determining a first horizontal feature angle (θHF
According to some aspects, disclosed is a mobile device for calibrating an inertial sensor, the mobile device comprising: means for capturing a first image, at a first time from the mobile device in a first orientation, wherein the first image contains a horizontal feature; means for determining a first horizontal feature angle (θHF
According to some aspects, disclosed is a non-transient computer-readable storage medium including program code stored thereon, for calibrating an inertial sensor, comprising program code for: capturing a first image, at a first time from the mobile device in a first orientation, wherein the first image contains a horizontal feature; determining a first horizontal feature angle (θHF
According to some aspects, disclosed is a mobile device for navigation using a reference wall, the mobile device comprising: an inertial sensor; and a processor and memory comprising code for: determining a reference angle (θREF) of the reference wall; determining an estimated direction of motion of the mobile device based on inertial sensor measurements from the inertial sensor; selecting a wall angle, closest to the estimated direction, equal to an integer multiple of 90° from the reference angle (θREF); and determining a direction of motion of the mobile device based on the wall angle.
According to some aspects, disclosed is a mobile device for navigation using a reference wall, the mobile device comprising: means for determining a reference angle (θREF) of the reference wall; means for determining an estimated direction of motion of the mobile device based on inertial sensor measurements; means for selecting a wall angle, closest to the estimated direction, equal to an integer multiple of 90° from the reference angle (θREF); and means for determining a direction of motion of the mobile device based on the wall angle.
According to some aspects, disclosed is a non-transient computer-readable storage medium including program code stored thereon, for navigation using a reference wall, comprising program code for: determining a reference angle (θREF) of the reference wall; determining an estimated direction of motion of the mobile device based on inertial sensor measurements; selecting a wall angle, closest to the estimated direction, equal to an integer multiple of 90° from the reference angle (θREF); and determining a direction of motion of the mobile device based on the wall angle.
According to some aspects, disclosed is a mobile device for navigation using a reference wall, the mobile device comprising: a camera; an inertial sensor; and a processor and memory comprising code for: capturing, with the camera in the mobile device, a local image containing a horizontal feature and the reference wall; determining a reference angle (θREF) of the reference wall; processing the local image to determine a horizontal feature angle (θHF), wherein the horizontal feature angle (θHF) measures an angle from a current orientation of the mobile device to the horizontal feature; and determining an angle of the current orientation of the mobile device based on a combination of the horizontal feature angle (θHF) and the reference angle (θREF).
According to some aspects, disclosed is a mobile device for navigation using a reference wall, the mobile device comprising: means for capturing a local image containing a horizontal feature and the reference wall; means for determining a reference angle (θREF) of the reference wall; means for processing the local image to determine a horizontal feature angle (θHF), wherein the horizontal feature angle (θHF) measures an angle from a current orientation of the mobile device to the horizontal feature; and means for determining an angle of the current orientation of the mobile device based on a combination of the horizontal feature angle (θHF) and the reference angle (θREF).
According to some aspects, disclosed is a non-transient computer-readable storage medium including program code stored thereon, for navigation in a mobile device using a reference wall, comprising program code for: receiving, from a camera in the mobile device, a local image containing a horizontal feature and the reference wall; determining a reference angle (θREF) of the reference wall; processing the local image to determine a horizontal feature angle (θHF), wherein the horizontal feature angle (θHF) measures an angle from a current orientation of the mobile device to the horizontal feature; and determining an angle of the current orientation of the mobile device based on a combination of the horizontal feature angle (θHF) and the reference angle (θREF).
According to some aspects, disclosed is a mobile device for providing calibrated inertial sensor measurements, the mobile device comprising: a camera; an inertial sensor; and a processor and memory comprising code for: determining a first reference angle (θREF
According to some aspects, disclosed is a mobile device for providing calibrated inertial sensor measurements, the mobile device comprising: means for determining a first reference angle (θREF
According to some aspects, disclosed is a non-transient computer-readable storage medium including program code stored thereon, for providing calibrated inertial sensor measurements, comprising program code for: determining a first reference angle (θREF
It is understood that other aspects will become readily apparent to those skilled in the art from the following detailed description, wherein it is shown and described various aspects by way of illustration. The drawings and detailed description are to be regarded as illustrative in nature and not as restrictive.
Embodiments of the invention will be described, by way of example only, with reference to the drawings.
The detailed description set forth below in connection with the appended drawings is intended as a description of various aspects of the present disclosure and is not intended to represent the only aspects in which the present disclosure may be practiced. Each aspect described in this disclosure is provided merely as an example or illustration of the present disclosure, and should not necessarily be construed as preferred or advantageous over other aspects. The detailed description includes specific details for the purpose of providing a thorough understanding of the present disclosure. However, it will be apparent to those skilled in the art that the present disclosure may be practiced without these specific details. In some instances, well-known structures and devices are shown in block diagram form in order to avoid obscuring the concepts of the present disclosure. Acronyms and other descriptive terminology may be used merely for convenience and clarity and are not intended to limit the scope of the disclosure.
Position determination techniques described herein may be implemented in conjunction with various wireless communication networks such as a wireless wide area network (WWAN), a wireless local area network (WLAN), a wireless personal area network (WPAN), and so on. The term “network” and “system” are often used interchangeably. A WWAN may be a Code Division Multiple Access (CDMA) network, a Time Division Multiple Access (TDMA) network, a Frequency Division Multiple Access (FDMA) network, an Orthogonal Frequency Division Multiple Access (OFDMA) network, a Single-Carrier Frequency Division Multiple Access (SC-FDMA) network, Long Term Evolution (LTE), and so on. A CDMA network may implement one or more radio access technologies (RATs) such as cdma2000, Wideband-CDMA (W-CDMA), and so on. Cdma2000 includes IS-95, IS-2000, and IS-856 standards. A TDMA network may implement Global System for Mobile Communications (GSM), Digital Advanced Mobile Phone System (D-AMPS), or some other RAT. GSM and W-CDMA are described in documents from a consortium named “3rd Generation Partnership Project” (3GPP). Cdma2000 is described in documents from a consortium named “3rd Generation Partnership Project 2” (3GPP2). 3GPP and 3GPP2 documents are publicly available. A WLAN may be an IEEE 802.11x network, and a WPAN may be a Bluetooth network, an IEEE 802.15x, or some other type of network. The techniques may also be implemented in conjunction with any combination of WWAN, WLAN and/or WPAN.
A satellite positioning system (SPS) typically includes a system of transmitters positioned to enable entities to determine their location on or above the Earth based, at least in part, on signals received from the transmitters. Such a transmitter typically transmits a signal marked with a repeating pseudo-random noise (PN) code of a set number of chips and may be located on ground based control stations, user equipment and/or space vehicles. In a particular example, such transmitters may be located on Earth orbiting satellite vehicles (SVs). For example, a SV in a constellation of Global Navigation Satellite System (GNSS) such as Global Positioning System (GPS), Galileo, GLONASS or Compass may transmit a signal marked with a PN code that is distinguishable from PN codes transmitted by other SVs in the constellation (e.g., using different PN codes for each satellite as in GPS or using the same code on different frequencies as in GLONASS). In accordance with certain aspects, the techniques presented herein are not restricted to global systems (e.g., GNSS) for SPS. For example, the techniques provided herein may be applied to or otherwise enabled for use in various regional systems, such as, e.g., Quasi-Zenith Satellite System (QZSS) over Japan, Indian Regional Navigational Satellite System (IRNSS) over India, Beidou over China, etc., and/or various augmentation systems (e.g., an Satellite Based Augmentation System (SBAS)) that may be associated with or otherwise enabled for use with one or more global and/or regional navigation satellite systems. By way of example but not limitation, an SBAS may include an augmentation system(s) that provides integrity information, differential corrections, etc., such as, e.g., Wide Area Augmentation System (WAAS), European Geostationary Navigation Overlay Service (EGNOS), Multi-functional Satellite Augmentation System (MSAS), GPS Aided Geo Augmented Navigation or GPS and Geo Augmented Navigation system (GAGAN), and/or the like. Thus, as used herein an SPS may include any combination of one or more global and/or regional navigation satellite systems and/or augmentation systems, and SPS signals may include SPS, SPS-like, and/or other signals associated with such one or more SPS.
As used herein, a mobile device 100, sometimes referred to as a mobile station (MS) or user equipment (UE), such as a cellular phone, mobile phone or other wireless communication device, personal communication system (PCS) device, personal navigation device (PND), Personal Information Manager (PIM), Personal Digital Assistant (PDA), laptop or other suitable mobile device which is capable of receiving wireless communication and/or navigation signals. The term “mobile station” is also intended to include devices that communicate with a personal navigation device (PND), such as by short-range wireless, infrared, wireline connection, or other connection—regardless of whether satellite signal reception, assistance data reception, and/or position-related processing occurs at the device or at the PND. Also, “mobile station” is intended to include all devices, including wireless communication devices, computers, laptops, etc. which are capable of communication with a server, such as via the Internet, WiFi, or other network, and regardless of whether satellite signal reception, assistance data reception, and/or position-related processing occurs at the device, at a server, or at another device associated with the network. Any operable combination of the above are also considered a mobile device 100.
Embodiments of the present invention use optically-based angle computations derived from images to calibrate less reliable angle measurements provided by sensors 330. Some applications use two interior images (e.g., of the same wall or of adjoining walls). Some applications use one interior image and one exterior image. Some applications use one interior image and one overhead map image. Some applications use one interior image and a table of building orientations. These embodiments may be used to calibrate sensors 330 such as gyrometers 336 and magnetometers 338.
Some applications assume exterior and interior walls are parallel and perpendicular to one another. Other applications are limited to buildings 110 known a priori to have square exterior walls. A lookup table or an overhead map or an overhead satellite image may identify which buildings 110 having square walls and may reference an exterior angle 210 (θEXTERIOR) for each building 110. Some applications assume interior walls are parallel and perpendicular to exterior walls. In other applications, a mobile device 100 limits application of algorithms described herein to buildings 110 known a priori to have interior walls parallel to exterior walls. Again, such compliant buildings 110 may be determined from a lookup table or an overhead map or an overhead satellite image.
Each angle described and used herein is assumed to have been converted to the horizontal plane such that the angle described may be measured from an overhead view. Also, embodiments assume that a horizontal feature 140 runs along and is parallel to interior walls. In execution, a mobile device 100: (1) determines a relative orientation of a horizontal feature 140 (referred to as a horizontal feature angle 355 (θHF
Some embodiments assume that a motion direction 250 (θMOTION) of a mobile device 100 follows a path 120 that is parallel interior walls. These embodiments may or may not use an image from a camera 320. Such embodiments may be accurate when the motion direction (θMOTION) is within and along a hallway 130, however, are less accurate when the motion direction (θMOTION) is within a room and motion is not necessarily aligned to parallel hallways 130. Though less accurate than the embodiments using images of horizontal features 140, such embodiments may be implemented without a camera 320.
Applying this assumed constraint to a horizontal feature 140 determined from a captured image and/or motion can assist in realigning dead reckoning or other navigation, recalibrating a gyrometer 336, recalibrating a magnetometer 338, and/or adjusting other measurements from the sensor 330 is described in further detail below.
At 312, the processor 310 receives one or more sensor measurements. The processor 310 processes the sensor measurements to form a sensor angle 365 (θSENSOR). The sensor angle 365 (θSENSOR) represents either: (1) a relative angle (e.g., amount of angular change of a mobile device 100 between capture times of two images) sensed by the mobile device 100; or (2) an absolute angle (e.g., a compass heading during a final image, or a final heading from dead reckoning) of the mobile device 100.
Throughout this disclosure, an absolute angle or absolute orientation may be written in the range from 0° to 360°. For example, any absolute angle (θ′) may be written as {θ=(θ′ modulo)360°}. Thus, 10° is equivalent to 370° is equivalent to −350°. A relative angle or relative orientation, however, should maintain its sign and magnitude of the angle, which may be less than 0° or greater than 360°, thereby accounting for a direction of rotation and a number of full and partial rotations. For example, 0° (representing no rotation) is not equivalent to 360° (representing a full rotation).
At 314, based on a final image, the processor 310 processes the image to determine a horizontal feature angle (θHF) (e.g., the first horizontal feature angle 355 (θHF
At 316, the processor 310 receives a first reference angle 350 (θREF
At 318, the processor 310 computes a sensor misalignment 370 (θERROR) based on a difference between the sensor angle 365 (θSENSOR) and the second reference angle 360 (θREF
Specific implementations are shown with relation to the following figures. Variations to
In
As shown in
where N is the number of sensor measurements. Each sensor measurement (Δθi) represents an incremental increase or decrease in rotation of the mobile device 100. For example, if a mobile device 100 is rotated at a constant rate of 50° per second and sensor measurements occur at a rate of 100 samples per second, then each sample on average would show an angular change of 0.5° per sample.
By integrating the several sensor measurements from a time an initial image was captured to a time the final image was captured, the processor 310 may compute a sensor angle 365 (θSENSOR). This sensor angle 365 (θSENSOR) may have accumulated error over the duration between the two images. Also shown are a first reference angle 350 (θREF
When a camera 320 captures two images of a common interior wall, the images may contain a common horizontal feature 140 from two different angles. When a camera 320 captures two images of two different interior walls, the two images may be of perpendicular or parallel walls and each image contains a different horizontal feature 140. In each case, a mobile device 100 rotates a relative angle between images. Based on the image processing of 314 and the computations of 316 and 318, this rotation angle is computed as a second reference angle 360 (θREF
In
In
In general, the processor 310 computes {θREF
In
At 312, the processor 310 produces an absolute angle as the sensor angle 365 (θSENSOR) oriented with respect to North 200. For example, the sensor angle 365 (θSENSOR) is set to a dead reckoning heading at a capture time of the final image. At 316, the processor 310 computes a second reference angle 360 (θREF
Some embodiments use the method described above to navigation using a mobile device using a reference wall. The mobile device determines a reference angle (θREF) of the reference wall. The reference wall may provide a reference angle (θREF) that is an absolute angle with respect to North. The reference wall may be an exterior wall or an interior wall. The reference angle (θREF) may be captured from an initial image and extracted from that image, may be determined based on the building that the mobile device is in, closest to or about to enter, may be found from an overhead map, and/or looked up from a table or other database.
The mobile device uses a camera or other optical sensor to capture an image of the local surroundings. If the local image contains a horizontal feature, the mobile device process the local image to determine a horizontal feature angle (θHF) of the horizontal feature. The horizontal feature may be a top edge of a door frame, a bottom edge of a closed door, an edge of a window frame and window, a name plate, a picture or poster hanging from a wall, the edge between the wall and the ceiling or floor, or an edge of a piece of furniture. The horizontal feature angle (θHF) measures a horizontal angle spanning from a current orientation of the mobile device to the horizontal feature. That is, it is a relative angle between to objects.
The mobile device next selects a wall angle of the horizontal feature. The wall angle is assumed to be either square or parallel to the reference wall. As such, the wall angle is equal to an integer multiple of 90° from the reference angle (θREF) following a modulo operation if the resulting wall angle is greater than a 360° span (e.g., 0° to 360° or −180° to +180°. For example, the wall angle may be set to one of four angles equal to modulo of (the reference wall+n*90°) with 360°, where n is a positive, negative or zero value integer. Using inertial sensors or a compass, the mobile device may make guess of which one of the four possible wall angles is the correct wall angle. Even if an inertial sensor direction has accumulated up to just under 45° of error, the mobile device selects the wall that is closest in direction. The difference between the selected wall angle and the sensor direction with accumulated error may be used to weight, reset and/or calibrate readings from the sensor. That is, a sensor misalignment (θERROR) may be derived from a difference between: (1) current orientation (θSENSOR) of the mobile device based on the inertial sensor measurements from the inertial sensor; and (2) an angle of the current orientation of the mobile device. The sensor misalignment (θERROR) may then be used to calibrate the inertial sensor.
The mobile device may then determine an absolute angle in the horizontal plane of the current orientation of the mobile device based on a combination of the horizontal feature angle (θHF) and the wall angle. This absolute angle may be used determine an updated position or direction of motion of the mobile device. For example, such an absolute angle may be used to assist a dead-reckoning algorithm.
In its rudimentary form, a mobile device may be assumed to be following an interior wall. That is, with or without a camera image, direction of motion of the mobile device may be limited to motion in line or perpendicular to the reference wall, thereby performing wall matching. In other embodiments with a camera, a mobile device navigates using wall matching with any horizontal feature to estimate motion. The mobile device captures a local image with a camera in the mobile device. The local image is an image of the immediate local area of the mobile device. If the local image contains a horizontal feature, the mobile device processes the local image to determine a horizontal feature angle (θHF). Again, the horizontal feature angle (θHF) is an angle in the horizontal plane spanning from a current orientation of the mobile device to the horizontal feature. The mobile device also estimated a direction of motion of the mobile device as one of four directions based on the horizontal feature angle (θHF) and assuming motion of the mobile device is parallel to the wall angle containing the horizontal feature.
The mobile device may also determine a reference angle (θREF) of a reference wall, wherein the reference angle (θREF) is an absolute angle with respect to North, then select a wall angle, of the horizontal feature, equal to an integer multiple of 90° from the reference angle (θREF), as described above. The mobile device may compute the reference angle (θREF) as described above, such as by capturing an initial image and then computing the reference angle (θREF) based on the initial image.
In some embodiments, a reference wall is used to calibrate an inertial sensor. The mobile device captures a first image, at a first time from the mobile device in a first orientation, wherein the first image contains a horizontal feature. The mobile device then determines a first horizontal feature angle (θHF
The mobile device also captures a second image, at a second time from the mobile device in a second orientation, wherein the second image contains a horizontal feature. The mobile device then determines a second horizontal feature angle (θHF
The mobile device then computes a difference between the first horizontal feature angle (θHF
In
In
At 312, the processor 310 processes the sensor measurements to form an absolute angle (sensor angle 365 (θSENSOR)). The sensor angle 365 (θSENSOR) may be a pass-through sensor measurement or may be a low pass filtered version of multiple sensor measurements and represents a heading as an absolute angle.
At 394, a table of exterior angles 210 (θEXTERIOR) if formed and is indexed by building locations. For this embodiment, a remote server may process an overhead map 392 to extract exterior angles 210 (θEXTERIOR) of various buildings 110 and may either provide this table to the mobile device 100 or may respond to a position estimate with an exterior angle 210 (θEXTERIOR) of the closest building 110.
In
The figures described above combined various types of sensor measurements with various sources for a first reference angle 350 (θREF
A second direction is a motion direction 250 (θMOTION), which is the direction of motion along the path 120 of the mobile device 100. A third direction is a horizontal direction 230 (θHORIZONTAL), which is the direction of a horizontal feature 140 in view of the camera 320. The horizontal direction 230 (θHORIZONTAL) is assumed to be one of the interior angles 220 (θINTERIOR). The horizontal feature 140 may be a top of a doorway, a bottom or top of a closed door, a bottom or top edge of a hallway 130, a bottom or top of a picture frame, a sign or name plate, a horizontal handrail, or similar horizontal feature 140. The path 120 is shown within a hallway 130 (for example, a person may be walking down the hallway 130).
If in motion, the motion direction 250 (θMOTION) may be generally in line with the horizontal direction 230 (θHORIZONTAL), which may be assumed to be parallel or perpendicular to the exterior angle 210 (θEXTERIOR). Thus, an inertial sensor 332 may be used to measure and accumulate the motion direction 250 (θMOTION), and a camera 320 may use image processing to search for a horizontal feature 140 and compute the horizontal direction 230 (θHORIZONTAL). For example, an accelerometer 334 may be used with a dead reckoning method. A current motion direction 250 (θMOTION) along path 120 may be mapped, constrained or restricted to a parallel/perpendicular direction as discussed above.
In
A third vector is mobile orientation 240 (θMOBILE), which is the direction the mobile device 100 is oriented, as explained above. A fourth vector is the horizontal direction 230 (θHORIZONTAL), which is assumed to be one of four angles parallel and perpendicular to the exterior angle 210 (θEXTERIOR). That is, the horizontal direction 230 (θHORIZONTAL) is mapped to one of {θEXTERIOR, θEXTERIOR+90°, θEXTERIOR+180°, θEXTERIOR+270°}. A fifth vector is an estimated horizontal direction (θEST
A mobile device 100 may adjust accumulated drift in a rough measured direction (θMEASURED), which is assumed to include accumulated error away from a perpendicular or parallel exterior wall, by adjusting the direction (θADJUSTED) to a direction that is closest to {θEXTERIOR, θEXTERIOR+90°, θEXTERIOR+180°, θEXTERIOR+270°}. Therefore, the measured direction (θMEASURED) is an input parameter and the adjusted direction (θADJUSTED) is an output parameter. For example, if a measured direction (θMEASURED) is in between two adjoining thresholds, then the measured direction (θMEASURED) is mapped as the adjusted direction (θADJUSTED) to be parallel or perpendicular to the exterior angle 210 (θEXTERIOR). That is, if {θEXTERIOR+45°<θMEASURED<θEXTERIOR+135°} then {θADJUSTED=θEXTERIOR+90°}. If {θEXTERIOR+135°<θMEASURED<θEXTERIOR+225°} then {θADJUSTED=θEXTERIOR+180°}. If {θEXTERIOR+225°<θMEASURED<θEXTERIOR+315°} then {θADJUSTED=θEXTERIOR+270°}. If {θEXTERIOR+315°<θMEASURED<θEXTERIOR+45°} then {θADJUSTED=θEXTERIOR}. In this case, a full range of input parameters (measured direction, θMEASURED) are mapped to one of four output parameters (adjusted direction, {θADJUSTED=DEXTERIOR+(n×90°)}, where n=0, 1, 2, 3).
In
A measured direction (θMEASURED) is close if it is within an angle θ from an of the four parallel/perpendicular exterior angle 210 (θEXTERIOR) (θEXTERIOR+n*90°). That is, if (θEXTERIOR+45°+θ<θMEASURED<θEXTERIOR+135°−θ) then (θADJUSTED=θEXTERIOR+90°). If (θEXTERIOR+135°+θ<θMEASURED<θEXTERIOR+225°−θ) then (θADJUSTED=θEXTERIOR+180°). If (θEXTERIOR+225°+θ<θMEASURED<θEXTERIOR+315°−θ) then (θADJUSTED=θEXTERIOR+270°). If (θEXTERIOR+315°+θ<θMEASURED<θEXTERIOR+45°−θ) then (θADJUSTED=θEXTERIOR). In this case, only this first sub-range of input parameters (measured direction, θMEASURED) is mapped to one of four output parameters (adjusted direction, θADJUSTED={DEXTERIOR+n*90°}, where n=0, 1, 2, 3).
If a measured direction (θMEASURED) is outside the first sub-range it is inside the second sub-range. The second sub-range of values for the measured direction (θMEASURED) is not mapped when the measured direction (θMEASURED) is outside of the angle θ from all of the four parallel/perpendicular exterior angle 210 (θEXTERIOR) (θEXTERIOR+n*90°). That is, when (θEXTERIOR+135°−θ<θMEASURED<θEXTERIOR+135°−θ) or (θEXTERIOR+225°−θ<θMEASURED<θEXTERIOR+225°−θ) or (θEXTERIOR+315°−θ<θMEASURED<θEXTERIOR+315°−θ) or (θEXTERIOR+45°−θ<θMEASURED<θEXTERIOR+45°−θ), the measured direction (θMEASURED) is not mapped. Therefore, only a measured direction (θMEASURED) close to a direction of a parallel/perpendicular wall (θEXTERIOR+n*90°) is mapped.
Embodiments above are described with relation to parallel and perpendicular exterior and interior walls. That is, embodiments are applied to four-side buildings with square and rectangular footprints and floor plans (i.e., wherein exterior and interior walls form respective angles of n*360/4° where n={0, 1, 2, 3}). Embodiments may be equally applied to multi-sided buildings having all square corners (e.g., an L′ shaped building). In such buildings, exterior walls are still parallel and perpendicular to one another. Embodiments are equally applicable and may be adjusted accordingly when walls are not all square but rather form other angles (e.g., having an equilateral triangle footprint, a right triangle footprint, a pentagon footprint). For example, a building 110 having an equilateral triangle footprint would constrain angles to n*360/3° where n={0, 1, 2}. A building 110 having a square triangle footprint could constrain angles to {0, 45, 90, . . . }. A building 110 having a pentagon footprint would constrain angles to n*360/5° where n={0, 1, 2, 3, 4}.
Embodiments above are described with relation to determining a reference angle or horizontal feature angle based on an orientation of an interior wall and an assumption that exterior walls and interior walls are parallel or perpendicular. Embodiments are equally applicable to exterior walls alone. That is, an interior wall may be substituted with an exterior wall. Therefore, a mobile device 100 may compute a horizontal feature angle based on an image containing a horizontal feature on an exterior wall. In this manner, a mobile device 100 may: (1) take one or two images of one or two horizontal features on one or two exterior walls; (2) compute an optically based relative or absolute angle; (3) compare this angle to a sensor based relative or absolute angle; and (4) form a sensor misalignment 370 (θERROR) based on the comparison.
The methodologies described herein may be implemented by various means depending upon the application. For example, these methodologies may be implemented in hardware, firmware, software, or any combination thereof. For a hardware implementation, the processing units or processor 310 may be implemented within one or more application specific integrated circuits (ASICs), digital signal processors (DSPs), digital signal processing devices (DSPDs), programmable logic devices (PLDs), field programmable gate arrays (FPGAs), processors, controllers, micro-controllers, microprocessors, electronic devices, other electronic units designed to perform the functions described herein, or a combination thereof.
For a firmware and/or software implementation, the methodologies may be implemented with modules (e.g., procedures, functions, and so on) that perform the functions described herein. Any machine-readable medium tangibly embodying instructions may be used in implementing the methodologies described herein. For example, software codes may be stored in a memory and executed by a processor unit. Memory may be implemented within the processor unit or external to the processor unit. As used herein the term “memory” refers to any type of long term, short term, volatile, nonvolatile, or other memory and is not to be limited to any particular type of memory or number of memories, or type of media upon which memory is stored.
If implemented in firmware and/or software, the functions may be stored as one or more instructions or code on a computer-readable medium. Examples include computer-readable media encoded with a data structure and computer-readable media encoded with a computer program. Computer-readable media includes physical computer storage media. A storage medium may be any available medium that can be accessed by a computer. By way of example, and not limitation, such computer-readable media can comprise RAM, ROM, EEPROM, CD-ROM or other optical disk storage, magnetic disk storage or other magnetic storage devices, or any other medium that can be used to store desired program code in the form of instructions or data structures and that can be accessed by a computer; disk and disc, as used herein, includes compact disc (CD), laser disc, optical disc, digital versatile disc (DVD), floppy disk and blu-ray disc where disks usually reproduce data magnetically, while discs reproduce data optically with lasers. Combinations of the above should also be included within the scope of computer-readable media.
In addition to storage on computer readable medium, instructions and/or data may be provided as signals on transmission media included in a communication apparatus. For example, a communication apparatus may include a transceiver having signals indicative of instructions and data. The instructions and data are configured to cause one or more processors to implement the functions outlined in the claims. That is, the communication apparatus includes transmission media with signals indicative of information to perform disclosed functions. At a first time, the transmission media included in the communication apparatus may include a first portion of the information to perform the disclosed functions, while at a second time the transmission media included in the communication apparatus may include a second portion of the information to perform the disclosed functions.
The previous description of the disclosed aspects is provided to enable any person skilled in the art to make or use the present disclosure. Various modifications to these aspects will be readily apparent to those skilled in the art, and the generic principles defined herein may be applied to other aspects without departing from the spirit or scope of the disclosure.