Determination of Relative Pose Using Artificial Magnetic Fields
20220136834 ยท 2022-05-05
Assignee
Inventors
Cpc classification
G01S5/00
PHYSICS
G01C21/16
PHYSICS
International classification
G01C21/16
PHYSICS
Abstract
The pose or position and orientation of a wearable sensor assembly in a reference coordinate system are to be determined in real-time. One or more artificial magnetic field sources are located with known positions and orientations in the reference coordinates. Each source generates a magnetic field which varies in time according to a predetermined AC pulse code, so that each source is uniquely identifiable and distinguishable from ambient DC fields. The magnitude and direction in wearable coordinates of the AC magnetic field due to each source varies in a modelable way with position and orientation of the wearable, which comprises a nine-channel Inertial Measurement Unit (IMU) and a processor. The IMU senses the inertial motion of the wearable and the time-varying magnetic field to which it's exposed. These data are processed to estimate the position and orientation of the wearable in reference coordinates, along with various constant parameters.
Claims
1. A method for determining relative pose, comprising one or more magnetic field Emitters, a Wearable sensor assembly whose pose is to be determined, and a Pose Estimation Algorithm.
2. The Emitters of claim 1, each said Emitter further having known location and orientation in an inertially fixed or nearly inertially fixed Reference Coordinate System.
3. The Emitters of claim 2, each said Emitter further modulating its output magnetic field with a predetermined AC pulse code.
4. The Wearable of claim 1, further comprising an Inertial Measurement Unit (IMU) and a Processor.
5. The IMU of claim 4, further comprising a three-axis Gyroscope, a three-axis Accelerometer, and a three-axis Magnetometer.
6. The Processor of claim 4, further reading data periodically from said IMU and processing said data in said Pose Estimation Algorithm.
7. The Pose Estimation Algorithm of claim 1, further comprising the twelve major steps Read IMU, Gyro Processing, Attitude Propagation, Accelerometer Processing, Position Propagation, Covariance Propagation or any method of uncertainty propagation, Magnetometer Processing, Synchronization, Magnetic Field Prediction, Magnetic Field Error, Measurement Update by Kalman Filter innovations or any state estimation method or any means of calculating parameter values from measured data, and Emitter Tracking Update.
8. An alternate method for determining relative pose, comprising one or more magnetic field Emitters, a Wearable sensor assembly without inertial instruments, and an appropriately modified Pose Estimation Algorithm.
9. A method for determining pose of one moving body relative to another, comprising one or more magnetic field Emitters mounted on a Reference Body, inertial instruments mounted on said Reference Body, a Wearable sensor assembly whose pose relative to the Reference Body is to be determined, and an appropriately modified Pose Estimation Algorithm.
10. A method for determining unknown components of relative pose, given that one or more components are already known, comprising one or more magnetic field Emitters, a Wearable sensor assembly with fewer than six channels of inertial instruments, and an appropriately modified Pose Estimation Algorithm.
Description
BRIEF DESCRIPTION OF THE DRAWINGS
[0045]
[0055]
[0060]
[0066]
[0079]
DETAILED DESCRIPTION OF THE INVENTION
First Embodiment (FIGS. 1 Through 4)
[0088] One embodiment of the invention is shown in
[0089] A Wearable device (130) is free to translate and rotate with respect to the Reference Coordinate System. Attached to the Wearable is its own Wearable Coordinate System (132). The Wearable senses the time-varying values of 1) its inertial angular velocity, 2) its nongravimetric inertial acceleration, and 3) the magnetic field to which the Wearable is exposed. The Wearable uses its sensed data to estimate in real-time the time-varying values of the position and orientation of the Wearable Coordinate System with respect to the Reference Coordinate System.
[0090]
[0091]
[0092] The Processor processes the sensor data with a strapdown navigation or Pose Estimation Algorithm as shown in
[0093] First, the current IMU outputs are read (400). Then the Gyro outputs are preprocessed (402) and used to propagate (404) the orientation or attitude estimate from its value at the previous sample time to its predicted value at the present sample time. Then the Accelerometer outputs are preprocessed (406) and used to propagate (408) the velocity and position estimates. Then the Gyro and Accelerometer data are used to propagate (410) the estimate covariance or uncertainty estimate.
[0094] Next, the Magnetometer outputs are preprocessed (412). Then, the recent history of the Magnetometer data is used to synchronize (414) the Wearable clock with the time base used by the Emitters.
[0095] After synchronization, if the pulse code has not incremented since the last sample, the algorithm terminates and the predicted position, velocity, and attitude are taken as the estimated position, velocity, and attitude. Otherwise, the algorithm continues as follows.
[0096] The propagated position and attitude are used to predict (416) the Magnetometer measurements. The predictions are differenced with those measurements to create error signals (418). Then a measurement update (420) is used to improve the estimates of all eighteen states, along with the covariance. The estimation algorithm is typically an Extended Kalman Filter, but it could also be an alternate estimation algorithm such as the Square Root Covariance Filter, Information or Square Root Information Filter, Particle Filter, Unscented Kalman Filter, Quadrature Kalman Filter, Cubature Kalman Filter, or other Bayesian or Least Squares estimation algorithm. It could also be an AI algorithm such as a convolutional neural network or any other data fusion algorithm.
[0097] Finally, a dynamic list of Emitters in range is updated (422). This list is used to improve the computational efficiency of the Synchronization step (414).
Advantages
[0098] The choice of states to estimate is based on our analysis of state observability, coupled with our experiments on performance of low cost IMUs and interfering DC magnetic fields (Fis1). This research provides guidelines for sizing and locating Emitters. It shows that two properly located Emitters are sufficient to produce pose estimates which are long term stable and accurate to centimeters; that Emitters placed periodically around a space of interest can provide unlimited coverage range; and that performance is rather insensitive to Emitter placement.
[0099] Our invention is ideal for use indoors, where GPS signals typically are not available. Because the Emitter fields are encoded AC, it is not sensitive to the Earth's magnetic field or spurious magnetic field sources. Unlike systems based on optical or RF signals, it does not require clear lines of sight from signal source to Wearable. It's also very low cost, as the Wearable can use IMU hardware found in existing mobile devices.
Second Embodiment
[0100] In another embodiment, the Wearable does not incorporate the Gyroscope and Accelerometer. While the system's time response may be slower, our research (Fis2) shows that two or more properly placed Emitters are sufficient to make the 6D pose observable from the Emitter magnetic fields alone. Alternately, data from any other type of pose sensor may be fused with the Magnetometer data to improve accuracy or response time.
Third Embodiment
[0101] In another embodiment, the Reference Coordinate System is not inertially fixed. For example, the Reference Coordinate System could be attached to a spacecraft in orbit, the Emitters could be mounted in that spacecraft, and the objective could be determination of the relative pose of a co-orbiting spacecraft (
Fourth Embodiment
[0102] In another embodiment, the Wearable is mechanically constrained to have fewer than six degrees of freedom. The Pose Estimation Algorithm is modified to take the constrained coordinates as given and estimate only the unconstrained coordinates. Sensors or individual sensor channels which become redundant may be eliminated.