The invention relates to a motion tracking system for tracking an object composed of object parts, connected by joints, in a three-dimensional space, and in particular, to a motion tracking system for tracking the movements of a human body.
Measurement of motion with a high resolution is important for many medical, sports and ergonomic applications. Further, in the film and computer game market, there is a great need for motion data for the purpose of advanced animation and special effects. Additionally, motion data is also important in Virtual Reality (VR) and Augmented Reality (AR) applications for training and simulation. Finally, real-time 3D motion data is of great importance for control and stabilization of robots and robotic devices.
There are a number of technologies available for tracking and recording 3D motion data. They generally require that an infrastructure be constructed around the object to be tracked. For example, one such system is an optical system that uses a large number of cameras, fixedly arranged around the object for which the motion is to be tracked. However, such optical measuring systems can only track the motion of an object in the volume which is recorded with the cameras. Moreover, a camera system suffers from occlusion when the view of the camera of the object is obstructed by another object, or when one or more cameras perform poorly, e.g., due to light conditions.
Systems which track position and orientation on the basis of generating magnetic fields and detecting the generated field with a magnetometer also require an extensive infrastructure around the object of interest. While such magnetic systems do not suffer from occlusion and will work in any light condition, they are nonetheless relatively sensitive to magnetic disturbances. Further, these systems need relatively large transmitters due to the rapid decrease in magnetic field strength over distance.
Other systems rely on mechanical or optical goniometers to estimate joint angles. However, such systems lack the capability to provide an orientation with respect to an external reference system, e.g., earth. Moreover, the mechanical coupling to the body of interest is cumbersome. While systems based on ultra-sonic sensors do not share all of the above problems, they are prone to disturbances such as temperature and humidity of the air as well as wind and other ultra-sonic sources. In addition, the range of such systems is often relatively limited and thus the amount of installed infrastructure is demanding.
In many cases, it is desired to measure motion data of body segments in an ambulatory manner, i.e., in any place, on short notice, without extensively preparing the environment. A technology which is suitable for this makes use of inertial sensors in combination with earth magnetic field sensors. Inertial sensors, such as gyroscopes and accelerometers, measure their own motion independently of other systems. An external force such as the measured gravitational acceleration can be used to provide a reference direction. In particular, the magnetic field sensors determine the earth's magnetic field as a reference for the forward direction in the horizontal plane (north), also known as “heading.”
The sensors measure the motion of the segment on which they are attached, independently of other system with respect to an earth-fixed reference system. The sensors consist of gyroscopes, which measure angular velocities, accelerometers, which measure accelerations including gravity, and magnetometers measuring the earth magnetic field. When it is known to which body segment a sensor is attached, and when the orientation of the sensor with respect to the segments and joints is known, the orientation of the segments can be expressed in the global frame. By using the calculated orientations of individual body segments and the knowledge about the segment lengths, orientation between segments can be estimated and a position of the segments can be derived under strict assumptions of a linked kinematic chain (constrained articulated model). This method is well-known in the art and assumes a fully constrained articulated rigid body in which the joints only have rotational degrees of freedom.
The need to utilize the earth magnetic field as a reference is cumbersome, since the earth magnetic field can be heavily distorted inside buildings, or in the vicinity of cars, bikes, furniture and other objects containing magnetic materials or generating their own magnetic fields, such as motors, loudspeakers, TVs, etc.
Additionally, it is necessary to know the length of the rigid bodies connecting the joints with accuracy in order to accurately compute the motion of a constrained articulated rigid body. However, it is often impossible to accurately measure the distance between the joints since the internal point of rotation for each joint is not exposed and easily accessible. For example, the rotation joint inside the human knee cannot easily be measured from the outside. An additional complication for externally measuring the location of a joint is that the joint location may not be fixed over time, but may change depending upon the motion being executed. This is the case with respect to the human knee and shoulder for example. Methods of calibrating such a kinematic chain to accurately calibrate the relative positions of the joints are known in the art, however, such methods still rely on accurate orientation sensing, which is cumbersome in areas with distorted Earth magnetic field as described above, when utilizing inertial and magnetic sensing units.
It is an object of the invention to provide a system, in which positions and orientations of an object composed of parts linked by joints, and in particular the positions and orientations of the object parts relative to one another, can be measured with respect to each other in any place in an ambulatory manner, without dependence on the Earth magnetic field as a reference for rotation around the vertical (heading).
It is a further object of the invention to provide a system in which the distance between the joints linking the object parts can be estimated accurately while using the system, or as part of a separate calibration procedure.
Other objects and features of the invention will be appreciated from reading the following description in conjunction with the included drawings of which:
The kinematic coupling (KiC) algorithm calculates (relative) orientation of two segments on each side of a joint. An inertial measurement unit aka IMU (3D accelerometer, 3D gyroscope, optionally equipped with a 3D magnetometer) is rigidly attached to each body segment. Only limited a-priori knowledge about the joint connection is needed to accurately determine the joint angle. This relative orientation between the two segments is essentially determined without using the local magnetic field as a reference for heading but using information derived from the joint acceleration.
The following initial assumptions are made:
The state vector is defined by:
x
t=[GΔpt GΔvt GaA,lowpass,t S
S
ωA,t=S
S
ωB,t=S
Where yacc and ygyr are defined as the signals from an accelerometer and gyroscope respectively (in m/s2) and (rad/s). The change in orientation between two time steps can be described with the quaternion:
Then calculating the next orientation is the quaternion multiplication:
q
GS
,t
=q
GS
,t−1
·Δq
A
q
GS
,t
=q
GS
,t−1
·Δq
B
The equations for predicting the new state vector are:
The manner in which the relative position is updated is illustrated in the segment diagram of
These equations are implemented for updating the state vector. The covariance matrix is updated with the equation Qx,t+1=A·Qx,t·A′+Qw, with A, the Jacobian matrix, given by:
Similarly, the process noise covariance matrix is:
It will be appreciated that the state and its covariance computed with dead reckoning can suffer from integration drift. This is optionally adjusted using the approximation that the average over time of the low passed acceleration in the global frame is zero, to obtain observability of inclination of the object segments:
In an embodiment of the invention, this acceleration update is only performed for one of the units, e.g., sensor A.
Optionally, a magnetic field measurement update can be used for multiple sensors, such that when there is no joint acceleration (and the relative heading is not observable using the joint acceleration) the relative heading is not drifting and the rate gyroscopes biases remain observable.
The third measurement update uses the information that the two segments 101, 103 are connected by the joint 105. It follows from
The measurement update equations are than defined by:
y=
GS
{circumflex over (R)}·
S
r
A−GS
C=[I
3
O
3
O
3−GS
After the measurement updates, the estimates of the orientation errors, S
To test the algorithm, a measurement was preformed using a well-defined mechanical system, a prosthesis 200, as illustrated in
From the foregoing, it will be appreciated that the relative heading becomes observable when the prosthesis is translated. The relative “heading” of the joint becomes observable when there are horizontal accelerations in the joint. In other words the relative heading is not observable when there is a perfect rotation around the joint centre or when there are only vertical accelerations (in the global frame), or when there is no movement or constant velocity (no acceleration) at all. To confirm this insight, several measurements were done where the prosthesis was rotated and translated.
A measurement was performed where the prosthesis 200 was rotated around the hinge, around sensor A and around the shoulder with the prosthesis held in extension of the arm. In
Theoretically, the relative heading would not be observable, but due to the difficulty of a perfect rotation around the hinge centre there will be small net horizontal accelerations and therefore the relative heading can be roughly estimated. This illustrates the sensitivity of the method. For the rotation around sensor A and for the rotation around the shoulder, the relative heading estimation converges faster to the correct relative heading and the uncertainties are decreased as well.
Subsequently, a measurement was done where the prosthesis 200 was translated along the x-, y- and z-axes. The calibrated data 700 from this measurement is shown in
In
For practical use, this concept as derived and demonstrated above can be extended to multiple segments, and indeed could be extended to an arbitrary number of joints and sensors. Also, it is not necessary in every embodiment to have a full IMU on each segment, or indeed a sensor at all on all segments. To demonstrate the practical application for a much used system of 3 segments connected by 2 joints, such as for example a leg or arm is derived below.
As example for demonstrating the KiC algorithm a leg 900 will be considered, e.g., the knee joint 901 connecting the upper leg (thigh) 903 with the lower leg (shank) 905 and the ankle joint 907 connecting the shank 905 with the foot 909 as shown in
The inputs
The outputs
The state vector consists of:
In total, there are 16 state variables and 48 states. The equations for updating the state estimates are:
There are several ways for writing down the relations for three segments connected by two joints.
The notion in the picture:
Measurement update 1:
G
p
B−GpA=GrA−GrB
When the state vector is known, the C matrix etc can be constructed via the equation below:
The state variables concerning this update are:
GpA, GpB, GvA, GvB, S
Measurement update 2:
G
p
C−GpB=GrB
G
{circumflex over (r)}
B2−G{circumflex over (r)}C=GpC−GpB−GS
When the state vector is known, the C matrix etc can be constructed given the equation above.
The state variables concerning this update are:
GpB, GpC, GvB, GvC, S
The measurement update assuming, that the average acceleration in the global frame over some time is zero, optionally need only to be applied done for one sensor, for example sensor A, the sensor mounted to the upper leg.
The joint is defined in a rather general manner: If two segments are said to share a joint, there exist a point on each of the two segments that have zero average displacement with respect to each other, over a pre-determined period of time. The location of this point is the joint position. The location of this point may change as a function of time or joint angle. Put in a different way, a joint is described as a ball and socket containing some positional laxity. As the segments on each side of the joint are assumed to be rigid, the position of this point is usually fixed and can be expressed with respect to segment (object) coordinates.
This can be seen in the example 1200 of
Using the relation of the Kinematic Coupling, the algorithm is able to supply the relative orientation between the two segments without using any assumptions on the local magnetic field during movements:
From the assumption that two segments are connected by a joint it follows that the acceleration of the joint is equal to the acceleration measured by the IMU's attached to the segments expressed in the joint position and expressed in the global coordinate frame. Or in other words, both IMUs should measure the same acceleration in the joint. This is demonstrated above.
If, for example, the orientation of the IMU attached to segment A is known, then the acceleration measured by this IMU can be expressed in the global coordinate frame and translated to the joint. Because the acceleration in the joint measured by the IMU attached to segment B must be equal to the acceleration measured by the IMU attached to segment A, the relative orientation, including rotation around the vertical, of the IMU attached to segment B is known, without using any information of the magnetometers. This method assumes that the location of the joint with respect to the IMUs (rA and rB) is known.
There is one important exception to the above: the relative orientation between the two segments can only be determined if the joint occasionally experiences some horizontal acceleration, e.g., during walking. The duration of such periods depends on the movement, the amount of correction needed due to rate gyroscope integration drift, the uncertainties of assumptions being made and settling time. For the case of the knee joint, a few steps of walking every 30 seconds would be sufficient for typical low-grade automotive rate gyros. In case the knee is not moving for much more than half a minute, the local relative heading could still be determined using the earth magnetic field, or optionally only used to limit any drift and make the rate gyro bias observable.
The accuracy of the joint position estimate with respect to the positions of the sensors on the segment should be known a priori, but, depending on the accuracy needed, does not need to be determined better than within 2-3 cm.
The inputs for the KiC Algorithm are:
The KiC algorithm assumes the distances between the joint and the origin of the IMUs attached to the segments to be known. Therefore the vector expressing the joint position in the object coordinate frame of segment A, OA, and the vector expressing the joint position in the object coordinate frame of segment B, OB, need to be given as input. These two vectors have to be set by the user. They can be obtained e.g., by measuring the joint position using a measuring tape.
A “scenario” controls the settings, e.g., the optional use of magnetometers, tuning parameters and initial settings used in the KiC algorithm. It specifies the characteristics of the movement and also parameters describing the uncertainties of assumptions being made.
Additionally, it can be shown using the above methods than instead of assuming the distance between the sensor A and sensor B and the joint to be known a priori, it can be left to the algorithm to estimate these distances. The disadvantage for this approach is that the distances in the state vector only become accurately observable when the system is excited enough. This may not be the case for a typical application and it will cause the algorithm to converge very slowly. Additionally, often the mounting location of the sensors with respect to the joint can be easily known, at least roughly. A huge advantage by letting the system automatically estimate the distances while using the system is that it can be very hard or impossible to actually measure the joint location accurately. This is also discussed above.
Furthermore, additional constraints can be added to the joint properties, e.g., a hinge with only 1 or 2 degrees of freedom, or other (mechanical) models can be used. Effectively this reduces the degrees of freedom of the joint and adds observability to the relative orientation estimates and/or the estimate of the distance between the IMUs end the joints. This can be advantageous in systems, such as such as prostheses, with well defined joints. However, it should be used with care for less defined systems, such as human joints, since an erroneous assumption will influence the accuracy of the system negatively.
In addition, the joint acceleration measurements can be further improved by combining the above described methods with other systems that can measure position, velocity and/or acceleration. For example UWB positioning systems or camera based systems can be used as input for a more accurate position/velocity/acceleration measurement.
It will be appreciated that the exact location of the accelerometer cluster inside the IMU is not critical, but the size of the accelerometer cluster inside the IMU should preferably be compensated for. It will be further appreciated that the disclosed principles have application far beyond measuring human motion. Indeed, the disclosed principles can be applied in any system that consists of one or more bodies comprising different segments connected by joints. Example environments for application of the disclosed principles include robots, sailing boats, cranes, trains, etc.
All references, including publications, patent applications, and patents, cited herein are hereby incorporated by reference to the same extent as if each reference were individually and specifically indicated to be incorporated by reference and were set forth in its entirety herein.
The use of the terms “a” and “an” and “the” and similar referents in the context of describing the invention (especially in the context of the following claims) are to be construed to cover both the singular and the plural, unless otherwise indicated herein or clearly contradicted by context. The terms “comprising,” “having,” “including,” and “containing” are to be construed as open-ended terms (i.e., meaning “including, but not limited to,”) unless otherwise noted. Recitation of ranges of values herein are merely intended to serve as a shorthand method of referring individually to each separate value falling within the range, unless otherwise indicated herein, and each separate value is incorporated into the specification as if it were individually recited herein. All methods described herein can be performed in any suitable order unless otherwise indicated herein or otherwise clearly contradicted by context. The use of any and all examples, or exemplary language (e.g., “such as”) provided herein, is intended merely to better illuminate the invention and does not pose a limitation on the scope of the invention unless otherwise claimed. No language in the specification should be construed as indicating any non-claimed element as essential to the practice of the invention.
Certain examples of the invention are described herein, including the best mode known to the inventors for carrying out the invention. Variations of those examples will be apparent to those of ordinary skill in the art upon reading the foregoing description. The inventors expect skilled artisans to employ such variations as appropriate, and the inventors intend for the invention to be practiced otherwise than as specifically described herein. Accordingly, this invention includes all modifications and equivalents of the subject matter recited in the claims appended hereto as permitted by applicable law. Moreover, any combination of the above-described elements in all possible variations thereof is encompassed by the invention unless otherwise indicated herein or otherwise clearly contradicted by context.