The present invention relates to a method and a system for determining a zero velocity state of an object, in particular whether a velocity of an object is below a predetermined threshold value. In particular, the present invention relates to a method and a system for determining a zero velocity state of an object based on measuring a plurality of accelerations of the object. Thereby, the method is in particular suitable for pedestrian dynamics modelling.
A position of an object located outdoors may be determined using the global positioning system (GPS) which relies on communications of the object to satellites orbiting the earth. In contrast, if the object is located indoors, communication to satellites may not be possible due to building structures with robust roofs or wall structures (in particular including an electrical conductor, such as a metal) surrounding the object and in particular surrounding a transmitter exchanging messages with the satellite.
For determining a position of an object, in particular a position of a pedestrian, located indoors a pedestrian dead reckoning (PDR) method and system may be applied. The pedestrian dead reckoning method utilizes small acceleration sensors which may be affixed to the body, in particular to a foot of the pedestrian. The acceleration sensor may also be referred to inertial measurement unit (IMU), containing gyroscopes and magnetometers as well and the pedestrian dead reckoning method may also be referred to as inertial navigation in the context of the present application. Indoor positioning may in particular be advantageous or required during emergency situations, such as a fire inside a building.
Unfortunately until now there were no mature technologies that are able to compute the current position of human beings within buildings with an adequate accuracy for a longer time and for changing movement types. Existing dead reckoning systems based on inertial technologies use a Kalman filter and either direct integration for foot mounted sensors or simple step recognition algorithms. The latter compute the track by adding fix step lengths under a measured angle. Improvements in angle accuracy can be achieved when combining these methods with map matching techniques (sensor-building model interaction). In the case of foot mounted sensors until now it has been difficult to compute the track for a longer time with the same sensor configuration, especially when movement types are changing often and quickly. The reason is that it is difficult to find proper zero-velocity states for uncommon movement patterns, there in fact velocities may never be really zero, or the time between two zero-velocity states is so long that drift and noise have an influence on the direct integration. In the case of body mounted sensors (e.g. DPM4000, Honeywell) it is difficult to recognize the movement direction. Stepping backwards e.g. can not be distinguished from moving forward with this sensor system.
From the publication by Glanzer et al. (“Semi-autonomous Indoor Positioning Using MEMS-based Inertial Measurement Units and Building Information”, Workshop on Positioning, Navigation and Communication 2009) it is known to use a micro electromechanical system (MEMS) based inertial measurement unit for measuring the acceleration and to use a mobile computer including a database with characteristic building information to establish an inertial navigation system. From the measured acceleration signals a distance traveled by the pedestrian over a certain time span may be calculated by a double integration.
However, it has been observed that the accuracy of the derived distance and also the thus derivable position, may not be high enough due to measurement errors. In particular, the measurement errors of the acceleration may lead to an inaccurate velocity which may lead to a drift of the position of the pedestrian as determined by the inertial navigation system even if the pedestrian is actually at rest, i.e. having zero velocity. Thus, it has been observed that so-called zero velocity updates (ZUPT) need to be applied in order to correct the measurement errors and to compensate the drift.
However, it turned out that it is difficult to accurately determine at which point in time the pedestrian is at rest (i.e. in a zero velocity state) and thus has a zero velocity.
The publication by Tome et al. (“Improving pedestrian dynamics modelling using fuzzy logic”, Tome P, Bonzon F., Merminod B. and Aminian K., EPFL Geodetic Engineering LAB and EPFL Laboratory of Movement Analysis and Measurement) proposes to perform a gate analysis using fuzzy logic to improve pedestrian dynamic modelling. However, the model may only be applied to determine whether the pedestrian walks, ascents or descents, but not to determine the precise velocity or position of the pedestrian.
The publication by Kwakkel et al, (“Foot and Ankle Kinematics During Gait Using Foot Mounted Inertial System”, Kwakkel SP., Godha S. and Lachapelle G., ION NTM, San Diego Calif., 22.-24.1.2007) proposes to use an inertial measurement unit for the kinematic analysis of foot/ankle rotations.
The publication by Yun et al. (“Self-contained Position Tracking of Human Movement Using Small Inertial/Magnetic Sensor Modules”, Yun X., Bachmann E. R., Moore H. and Calusdian J., Proceedings of IEEE International Conference on Robotics and Automation, Roma, Italy, 10.-1442007) discloses a position tracking system using inertial/magnetic sensors attached to the human to calculate the position during walking and running. Thereby, short periods of zero foot velocity when the foot is in contact with the ground are taken into account to allow drift error correction. The periods of zero foot velocity are determined, if the acceleration is within a threshold for a specific period of time.
There may be a need for a method and a system for determining whether an object is in a zero velocity state, in particular whether the velocity of an object is below a predetermined threshold value, in particular whether the object has zero velocity, which provides higher accuracy. Further, there may be a need for a method and system for determining a coordinate of an object which method is based on measuring accelerations and which provides coordinates of an object, i.e. three-dimensional positional information providing a higher accuracy. Further, there may be a need for a method for determining a coordinate of an object, the method relying on measured accelerations, wherein a drift problem has been reduced.
According to an embodiment a method for determining a zero velocity state, in particular whether a velocity of an object is below a predetermined threshold value, in particular whether a velocity of an object is zero, comprises measuring a plurality of accelerations of the object within a time interval from a point in time to a later point in time; deriving information indicative of a plurality of velocities of the object within the time interval based on the measured accelerations; and determining whether the velocity is below the predetermined threshold value at the point in time by applying a criterion based on the derived information indicative of the plurality of the velocities.
The object may be any object which moves (in particular relative to the inertial system at the surface of the earth where the object is situated or moves), wherein the movement comprises at least one period in time where the object has a zero velocity, or a velocity smaller than a predetermined threshold value, relative to the inertial system of the earth. In particular, the motion of the object may be according to a repeating motion pattern. The motion pattern may comprise periods, wherein the object moves with a non-zero velocity and may also comprise periods where the object is at rest, i.e. has zero velocity in the inertial system of the earth.
In particular, the object may be a living creature, such as an animal or a human being. Further in particular, the object may be a pedestrian moving while in an upright position, in a lying position or in a flexed position, wherein the moving is performed using the body resources of the pedestrian, such as his muscles and his own biological energy. The pedestrian may for example walk, run, crawl or perform a combination of the aforementioned motion patterns. In particular, the motion of the pedestrian may be at least approximately periodic. Further, the pedestrian may move according to a first motion pattern during a first time period and may then move according to a second motion pattern different from the first motion pattern during a second time period later than the first time period. In particular, the pedestrian may first walk for a while, then may run for a while, then ascend stairways, descend stairways or perform these motion patterns in an arbitrary sequence or arbitrary order.
The method may be used to determine when it should be assumed that the velocity of the object is zero for improving the accuracy of a method for determining a coordinate of the object, in order to reduce a drift problem involving erroneous determination of the velocity of the object. Thus, the method may be designed such that periods during which the velocity of the object should be set to zero are identified, in order to improve an accuracy of a determination of a position of the object, although during these identified periods in time the velocity of the object may not necessarily be actually zero relative to the inertial system of the earth.
In the context of the present application a zero velocity state may be a state in which the object has a velocity less than a predetermined threshold, in particular less than 0.05 m/s, more in particular less then 10 mm/s, more in particular less than 1 mm/s, more in particular less than 0.1 mm/s, more in particular essentially zero m/s, wherein the velocity is measured in the local inertial system of the surface of the earth at the location of the object.
Measuring the plurality of accelerations may comprise measuring a plurality of accelerations in one, two or three different directions, such as a x-direction, a y-direction and a z-direction which may be orthogonal to each other. Measuring the accelerations may for example be performed using an inertial sensor and/or a magnetic sensor, in particular using a micromechanical inertial measurement unit (IMU). Further, the measuring the accelerations may involve applying a Kalman filter. In particular, the IMU may be mounted close to the pedestrian's foot, such as integrated or mounted at a shoe. The accelerations may be measured continuously or by sampling the accelerations at certain sample time intervals between the point in time to the later point in time. In particular, the sampling time intervals may be equidistant sampling time intervals. In particular, the sampling time intervals may be between 0.005 seconds and 0.5 seconds.
From the plurality of accelerations of the object information may be derived which is indicative of a plurality of velocities of the object within the time interval. Deriving this information may comprise performing a summation of accelerations, in particular an integration of accelerations, over different time intervals. According to an embodiment, the derived information indicative of the plurality of velocities represents the velocities of the object (in particular in the inertial system of the earth as introduced above). According to other embodiments the plurality of velocities of the object within the time interval may at least be derivable from the derived information indicative of the plurality of velocities of the object. In particular, deriving the actual velocities of the object may require a knowledge of at least one initial velocity. Thus, without this additional information it may not be possible to derive the actual velocities of the object solely based on the measured plurality of accelerations.
Utilizing the derived information indicative of the plurality of the velocities (within the time interval from the point in time to the later point in time) the criterion may be established based on which it may be determined whether the object is in a zero velocity state, in particular whether the velocity is below the predetermined threshold value, at the point in time, in particular whether the velocity is zero at the point in time.
Thus, information of the movement of the object of at east one point in time later than the point in time is used to determine whether the velocity is below the predetermined threshold value (or is zero) at the point in time. Thus, information indicative of the velocity of the object at a time later than the point in time is required to determine whether the velocity is zero (or below the predetermined threshold value) at the point in time. Using the information indicative of the velocity of the object at times later than the point in time may improve the determination whether the velocity is zero (or below the predetermined threshold value, or whether the object is in a zero velocity state). In particular, an evolution of the velocity after the point in time may be taken into account for determining whether the object is in a zero velocity state. In particular, the evolution of the velocities later than the point in time may depend on a motion pattern and may have a recognizable characteristics which may allow a more accuracy determination whether the object is in a zero velocity state.
The criterion may be a logical criterion, in particular comprising several sub-criteria which may be combined using logical operations such as a logical AND and/or a logical OR.
According to an embodiment the criterion comprises a factor depending on a quantity indicative of the velocities, in particular a maximum of the velocities, since a last determination that the velocity of the object is below the predetermined threshold value.
By providing that the factor depends on a quantity indicative of the velocities, in particular a maximum of the velocity since the last determination that the velocity of the object is zero (or below the predetermined threshold value) a change of the motion of the object from one motion pattern to a second motion pattern different from the first motion pattern (in particular having higher average or maximum velocities) may be taken into account. Thus, the method may in particular be applied to a moving object which changes its motion pattern over time. Irrespective of a change of the motion pattern the determination that the object is in a zero velocity state may nevertheless be accurate.
In particular, the factor may be represented by a mathematical function on the maximum of the velocity since the last determination that the velocity of the object is zero or below the predetermined threshold value. According to an embodiment the criterion comprises a factor depending on an average of the velocity since a last determination that the object is in a zero velocity state. According to an embodiment the criterion comprises a factor depending on a quantity representing an overall magnitude or a maximum of the velocity since a last determination that the object is in a zero velocity state. In particular, the factor may change over time in accordance with a change of a motion pattern of the motion of the object. Thereby, the accuracy of the determination of a zero velocity state of the object may be improved.
According to an embodiment the factor increases when the maximum of the velocity since the last determination that the object is in a zero velocity state increases. According to an embodiment the factor increases when an average of the velocity since the last determination that the object is in a zero velocity state increases. Thereby, in particular the criterion applied to determine the zero velocity state of the object may be adaptable to different motion patterns of the object. Thereby, the criterion may become context sensitive for improving the determination of the zero velocity state of the object.
According to an embodiment the factor increases (when the maximum of the velocity increases) according to a polynomial, in particular a polynomial of third order in the maximum velocity. In particular, the polynomial may be characterized by coefficients of the terms of different order in the maximum of the velocity (or average of the velocity or a quantity representing an overall magnitude of the velocity). Thereby, the dependence of the factor on the motion pattern (in particular the dependence on a quantity indicative of the velocities since the last determination that the object is in a zero velocity state) may be simplified. Thus, the criterion may be applied to different motion patterns without complicating the computation or without requiring extensive computation time in particular without switching to another criterion.
According to an embodiment a form of the dependency of the factor on the maximum velocity (or average velocity or quantity indicative of the velocities since the last determination that the object is in a zero velocity state) is determined such that a determination that the object is in a zero velocity state is refined, when the object moves according to a predefined motion pattern.
In particular, the form or shape of the dependency of the factor on the quantity indicative of the velocities of the object since the last determination that the object is in a zero velocity state (or that the velocity of the object is zero or below the predetermined threshold value) may be learnt from training data providing measured accelerations for a number of different motion patterns and providing also information about the zero velocity states. The learning may comprise any machine learning algorithm, such as multiple regression, neuronal network, and others.
According to an embodiment the predetermined motion pattern may be a motion pattern selected from the group consisting of walking, running, crawling, descending, and ascending. According to an embodiment the predetermined motion pattern may automatically be recognised from the aforementioned group of motion patterns. The different motion patterns may be different with respect to average velocity/acceleration, maximum velocity/acceleration, minimum velocity/acceleration, time period between two zero velocity states (also referred to as cycle period of the motion pattern), movement direction (for example horizontal or/and vertical) and others. Thereby, the method may be refined or even optimized for a particular set of motion patterns which are expected to be carried out by the object, in particular the pedestrian, depending on the particular application.
According to an embodiment the criterion is satisfied if a first criterion or a second criterion is satisfied. By splitting the criterion into two partial criteria joined by a logical OR the computational demand of the method may be reduced and simplified. If at least the first criterion is satisfied, according to an embodiment it is determined that the object is in a zero velocity state. If at least the second criterion is satisfied, according to an embodiment, it is determined that the object is in a zero velocity state.
According to an embodiment the first criterion comprises a determination whether the acceleration at the point in time (or an average of the acceleration around the point in time) is below an acceleration threshold. In particular, the acceleration threshold may be a quantity indicative of a minimum of the plurality of measured accelerations. Thus, in particular the acceleration threshold may vary in time and may depend on the motion pattern of the object. According to an embodiment the first criterion comprises a determination whether the acceleration at the point in time is equal to a minimum of the plurality of measured accelerations (or less than 1.3, in particular less than 1.1, times the minimum of the plurality of measured accelerations). Thereby, the first criterion may comprise the determination whether the acceleration at the point in time is smaller than all (or a majority of all) subsequent accelerations measured from the point in time to the later point in time. Thereby, it may be excluded that within the time interval from the point in time to the later point in time an acceleration occurs which is smaller than the acceleration at the point in time.
According to an embodiment the first criterion comprises a determination whether the velocity at the point in time is smaller than a product of the factor, a quantity depending on a time period since the last determination that the object is in a zero velocity state (or that the velocity of the object is below a predetermined threshold value or is zero), and a velocity tolerance value. The factor may take into account that the motion pattern of the motion of the object may change. The quantity depending on the time period since the last zero velocity state may account for a typical cycle period or typical cycle periods of different motion pattern(s) and may tend to determine that the object is in a zero velocity state the greater the time since the last determination of a zero velocity state is. Thereby, zero velocity states for complex motions comprising a number of motion patterns may be determined.
According to an embodiment the second criterion comprises a determination whether the velocity at the point in time is below a velocity threshold. According to an embodiment the second criterion comprises a determination whether the velocity at the point in time is smaller or equal to a quantity indicative of a minimum of the plurality of the derived velocities (or smaller than 1.3, in particular 1.1 times the minimum of the plurality of the derived velocities). Thereby, the velocity threshold may vary with time and may in particular depend on the motion pattern of the motion of the object. In particular, when it turns out that the velocity at an instance in time after the point in time but before the later point in time is smaller than the velocity at the point in time, then the second criterion will not be satisfied. Thereby, the method looks ahead of time up to the later point in time in order to check whether velocities occur which are still smaller than the velocity at the point in time. If these smaller velocities occur, then the second criterion will not be satisfied. Thereby the method may determine that the object is not in a zero velocity state, unless the first criterion is satisfied.
According to an embodiment the second criterion comprises a determination whether the measured acceleration at the point in time is smaller than a product of the factor, a quantity depending on a time period since the last determination that the object is in a zero velocity state, and an acceleration tolerance value.
Again the appearance of the factor in the product may take into account different motion patterns of the motion of the object. Further, the quantity depending on the time period since the last determination of a zero velocity state of the object may reflect typical cycle periods of different motion patterns, wherein in particular the quantity may increase with increasing time since the last determination of a zero velocity state. In particular, for a given motion pattern it may be expected that there exists a typical cycle period between two zero velocity states of an object proceeding according to this particular motion pattern. Thereby, the determination of a zero velocity state may be further improved.
According to an embodiment the quantity (depending on a time period since the last determination that the object is in a zero velocity state or that the velocity of the object is below the predetermined threshold value) depends linearly (in particular with a positive gradient) on the time period since the last determination that the object is in a zero velocity state. Thus, the longer the time period since the last determination of a zero velocity state of the object the more probable it becomes that either the second criterion or the first criterion is satisfied. However, the first criterion and also the second criterion may comprise further partial criteria which are possibly combined by logical conjunctions.
According to an embodiment the measuring the plurality of accelerations of the object within the time interval from the point in time to the later point in time comprises measuring the accelerations at a frequency between 50 Hz and 200 Hz, in particular between 70 Hz and 150 Hz. In particular, the frequency of measuring the accelerations may depend on the motion pattern expected for the object. In particular, the frequency may be higher the higher the velocities comprised in the motion pattern are. The frequency may in particular be adapted to determine zero velocity states of a moving pedestrian. With these frequencies zero velocity states of a walking, running, crawling, ascending or descending pedestrian may be accurately determined.
According to an embodiment the measuring the plurality of accelerations of the object within the time interval from the point in time to the later point in time comprises measuring 20-60 accelerations, in particular 30-50 accelerations. in particular, the time interval may be selected such that it is less than 1.0, in particular less than 0.5, further in particular less than 0.4, times a cycle period of the motion pattern. in particular, if the motion pattern is a motion pattern of walking, the cycle period may be defined as the (average) time between two footsteps. Thereby, it may be avoided that the method for determining zero velocity state misses a footstep which could occur if the time interval would exceed the cycle time period of the motion pattern under consideration.
According to an embodiment a method for determining a coordinate of an object is provided, wherein the method comprises: determining that the object is in a zero velocity state (or whether the velocity of the object is below a predetermined threshold value or is zero) according to an embodiment of the method of determining whether a velocity of an object is below a predetermined threshold value (or is zero) according to an embodiment described above; and deriving the coordinate of the object based on the determining whether the velocity of the object is below the predetermined threshold value and based on the measured acceleration at the point in time.
Thereby, the coordinate of the object may comprise three positions of the object along three different directions, such as an x-position, measured along the x-axis, a y-position measured along the y-axis and a z-position measured along the z-axis. Other coordinate systems for defining a position of the object, such as a spherical coordinate system, a cylindrical coordinate system or others may be possible. The coordinates may be coordinates in any inertial coordinate system, such as the inertial system of the earth, in particular at the location of the object.
Deriving the coordinate of the object may comprise integrating the acceleration or summing the acceleration(s) over time, in particular performing a double integration of the acceleration. Due to one or more unknown integration constants the coordinate of the object may be ambiguous. Any information indicative of a position of the object (also one that comprises the position of the object offset by an unknown quantity) may be considered to represent a coordinate of the object. By applying the method for determining that the object is in a zero velocity state (or whether a velocity of an object is below a predetermined threshold value) to a method for deriving the coordinate of the object the derivation of the coordinate of the object may be improved regarding accuracy. in particular, uncertainties of the determination of the coordinate due to drift problems (inaccurate velocities) may be reduced.
According to an embodiment an apparatus for determining that an object is in a zero velocity state (or whether a velocity of an object is below a predetermined threshold value or is zero or corresponds to a zero velocity state) is provided, wherein the apparatus comprises an inertial sensor adapted for measuring a plurality of accelerations of the object within a time interval from a point in time to a later point in time; and a processing system adapted for deriving information indicative of a plurality of velocities of the object within the time interval based on the measured accelerations, and for determining whether the velocity is below the predetermined threshold value (or is zero or corresponds to a zero velocity state) at the point in time by applying a criterion based on the derived information indicative of the plurality of the velocities.
In particular, the apparatus may be provided as an integrated solution comprising the acceleration sensor and the processing system which may comprise program code implementing the method for determining that the object is in a zero velocity state (or whether the velocity of the object is below the predetermined threshold value). In particular, an apparatus for determining a coordinate of an object is provided which performs an embodiment of a method for determining a coordinate of an object. The apparatus may be adapted to perform the drift correction by determining the zero velocity states of the object and may further be adapted for transmitting the coordinates of the object to a base station without requiring that the base station performs an additional correction of the coordinates, such as drift correction. Thereby, the transmitter comprised in the apparatus may transmit only a limited amount of data, such as three coordinates of the object instead of transmitting plural accelerations, plural velocities at plural subsequent points in time.
According to an embodiment a system for determining a coordinate of an object is provided, the system comprising: an inertial sensor for measuring a plurality of accelerations of the object within a time interval from a point in time to a later point in time; and a processing system for receiving the plurality of measured accelerations, wherein the processing system is adapted to derive indicative of a plurality of velocities of the object within the time interval based on the plurality of measured accelerations; and to derive the coordinate of the object based on at least one of the plurality of accelerations and based on a determination whether the velocity is below a predetermined threshold value at the point in time based on a criterion comprising indicative of the plurality of velocities.
It has to be noted that embodiments of the invention have been described with reference to different subject matters. In particular, some embodiments have been described with reference to method type claims, whereas other embodiments have been described with reference to apparatus type claims. However, a person skilled in the art will gather from the above and the following description that, unless otherwise notified, in addition to any combination of features belonging to one type of subject matter also any combination between features relating to different subject matters, in particular between features of the method type claims, and features of the apparatus type claims, is considered as to be disclosed with this document.
The aspects defined above and further aspects of the present invention are apparent from the examples of embodiment to be described hereinafter and are explained with reference to the examples of embodiment. The invention will be described in more detail hereinafter with reference to examples of embodiment, but to which the invention is not limited.
The positioning and navigation of pedestrians using inertial systems requires a two-time integration of the accelerations to determine the position and covered distance. Due to the measurement uncertainty of the accelerations, it may be necessary to use the smallest possible integration intervals. Therefore, the sensors may be mounted to the foot. A state of zero velocity may arise for a brief moment when the foot touches the ground. Depending on the movement type, however, this condition may be difficult to determine by conventional methods. The new algorithm disclosed herein may allow for reliable, rapid determination of zero velocity states, using the same parameters for all types of movement (walking, running, seals, mountain climbing, etc.).
According to an embodiment the system 100 is a small device (of the order of 10 cm by 10 cm by 5 cm or even smaller) which may be carried by a pedestrian, e.g. mounted at a foot of the pedestrian. The inertial management unit 101 comprises three acceleration sensors 105 for measuring accelerations in three different directions, such as in the x-direction, in the y-direction and in the z-direction. In particular, the inertial sensor 101 may comprise a low cost micro electromechanical system (MEMS) sensor. The inertial sensor 101 further comprises three orthogonal magnetometers 107 for measuring the direction of the magnetic field of the earth. Further, the inertial sensor 101 comprises three orthogonal gyroscopes 109 for measuring changes in the orientation of the object. Measuring data acquired by the magnetometers 107 and the gyroscopes 109 are supplied to a stabilizing unit 111 for correction and stabilization of the measured data.
The acceleration data and the orientation data acquired by the inertial sensor 101 are supplied to the processing system 103 via data lines 113. The processing system 103 performs processing of the data, such as coordinate transformation 115, subtraction of gravitation 117, motion recognition 119. Further, the processing system comprises a processing module 121 for determining the velocities of the object, in particular the pedestrian, carrying the system for determining a coordinate 100.
Within the processing module 121 the determination of the velocities of the object comprises integrating the measured accelerations over time. As the acceleration sensor 105 measures the accelerations at a frequency of 100 Hz the integration is performed by a discrete summation of the measured accelerations.
As the measurement of the accelerations is error-prone also the determination of the velocities of the object is inaccurate unless the velocities are regularly corrected, in particular unless expected zero velocity states are identified followed by an according correction of the velocity. In particular, zero velocity states (these are states of movement of the object or the pedestrian, wherein the velocity of the object in a local inertial system at the surface of the earth is below a predetermined threshold, in particular below 0.05 m/s, 0.01 m/s or even smaller) are identified for correction of the velocities. If these corrections were not performed the determination of the coordinates from the velocities would be largely inaccurate as well.
Therefore, the processing module 121 performs a method for determining a zero velocity state of the object based on the measured accelerations. This method is described in more detail with reference to
Having determined that the object is in a zero velocity state the velocities originally derived from the measured accelerations are accordingly corrected (set to zero for instances in time for which a zero velocity state has been determined). The thus corrected velocities then form the basis for the calculation of the coordinates by the processing module 123 using an integration algorithm. it should be noted that the measuring the accelerations, correcting the velocities derived from the measured accelerations and calculation of the coordinates from the corrected velocities is entirely performed within the system 100 for determining a coordinate of an object without requiring performing the correction by an external facility.
The system 100 may further comprise a (not illustrated) transmitter (and/or receiver) module for transmitting the coordinates calculated by the processing unit 123 to a base station tracking the motion of the object. Thereby, only the finally calculated coordinates may be transmitted to the base station without the need to transmit plural accelerations measured over a time period to the base station. Thereby, the amount of data to be transmitted to the base station may be reduced.
Body-mounted inertial measurement units (IMUs) may allow for indoor positioning without preinstalled infrastructure. Beginning at a defined starting point in the building or somewhere in its surrounding the movements of a person may be tracked by numerical double integration of the sensor's accelerations in three local directions. Transforming the local paths into the global system the current position may be determined. At the moment the indoor positioning system (IPS), developed at Graz University of Technology is designed as core component of a computer aided disaster management system (CADMS). The advances in technology of mobile and smart phones (e.g. integration of inertial sensors) may allow using the system in everyday applications (e.g. navigation in large underground structures, shopping centers, airports, etc.).
Unfortunately over time the measurement errors of such a conventional IPS may grow and the exact position cannot be calculated relying on a permanent integration. The positioning precision may be improved by the technique of so called “zero velocity updates”, i.e. the integration may performed only within short interval(s), where the velocity of the IMU is not zero. So the precision problem may be reduced to identify zero velocity states. To get periodical moments of zero velocity, the IMU may be mounted e.g. at the foot.
Unfortunately the detection of real zero velocity states may not be reliable in conventional systems. Even within the short time of about 1 second for one footstep, noise and drift of the IMU may be considerable, furthermore field test have shown that the precision in detecting zero velocity states, also depends on the movement type and equipment of the moving person.
Therefore, specialised algorithms analysing the movement patterns (walking, running, crawling, ascending or descending stairs) have been developed. They improve the pure integration significantly, because typical effects of IMUs like noise and drift may be suppressed or corrected, as well as the characteristics of the movement type may be taken into account.
The algorithms for determining a zero velocity state is time and movement type dependent and allows for the detection of zero velocity states for any movement type during a long time. The algorithm is fully parameterized, so it can be adapted to special environment conditions (e.g. ground floor material, equipment or anatomy of the user).
According to an embodiment a zero velocity state (the velocity of the object is below a predetermined threshold, such as below 0.01 m/s, below 0.005 m/s, or is substantially 0) is determined, if at least a first criterion or a second criterion based on a derived information indicative of a plurality of velocities of the object is satisfied.
Herein, the first criterion (C1) is defined as:
(as(t)=as(min)|vs(t)−vs(min)|<Δv*fvvs(t)<vfas(t-1)>as(t))
and the second criterion (C2) is defined as:
(vs(t)=vs(min)as(t)<af)
Thereby, the following nomenclature is used:
of average of the acceleration in the direction of motion at the time t in the interval t to t+n·dt
n=number of chosen average values of the acceleration in the direction of motion
dt=integration time interval
as(min)=norm of minimum of the acceleration in the direction of motion in the interval t to t+m˜dt.
m=number of subsequent accelerations in the direction of motion from which a minimum is determined
vs(t)=norm of velocity in the direction of motion at time t
vs(min)=norm of minimum of the velocity in the direction of motion in the interval t to t+m·dt
Δv=tolerance value for the maximal, norm of velocity in the zero velocity range
f
v
=A*v
max
3
+B*v
max
+C=a factor
vmax=maximal velocity since the last zero velocity state
A, B, C=factors evaluated from experiments performed for different motion patterns
vf=Δv*fv*(1+Δt)=tolerance value for the maximal norm of average velocity in the zero velocity region
Δt=time since the last zero velocity state
af=Δa*fv*(1+Δt)=tolerance value for the maximal norm of average acceleration in the zero velocity region.
The criterion (denoted as C*) is determined by combining the first criterion (C1) and the second criterion (C2) by a logical OR. Thus, it is determined that the object is in a zero velocity state, if at least one of the first criterion or the second criterion is satisfied. The first criterion as well as the second criterion each comprises a number of sub-criteria which are connected by a logical AND. Thus, the first criterion is satisfied, if all of the sub-criteria of the first criterion are satisfied and the second criterion is satisfied, if all of the sub-criteria of the second criterion are satisfied.
In other embodiments the first criterion may comprise at least one of the sub-criteria of the first criterion, but not all. According to an embodiment the second criterion may comprise at least one of the sub-criteria of the second criterion, but not all.
as(t) is the norm of an average of the measured accelerations, wherein the average is formed over n measured accelerations. According to an embodiment n is between 2 and 8, in particular between 3 and 5, in particular 4.
dt denotes the time interval between two subsequent measurements of the acceleration. According to an embodiment dt is between 1/1000 s and 1/10 s, in particular around 1/100 s. The averaging the measured acceleration may smooth the acceleration in order to reduce outlier spikes and unrealistic peaks of the acceleration.
as(mint) denotes the norm of the minimum of the acceleration within the interval t to t+m·dt. Thereby, the time interval m·dt denotes the time interval after the time t in which measured accelerations are taken into account in order to determine whether the object is in a zero velocity state. Thus, the algorithm looks ahead of the time point t to decide whether at time t the object is in a zero velocity state.
According to an embodiment m is between 10 and 60, in particular 30-50, in particular around 40. Further, according to an embodiment, the product m·dt is chosen such that it is less than a cycle period of an expected motion pattern of the object. For example, if the motion pattern is walking the cycle period of this motion pattern may be defined as the time period between two footsteps. According to an embodiment the product m·dt is less than 0.5, in particular less than 0.3, times the cycle period of the motion pattern. If the object is expected to move according to a number of different motion patterns the product m·dt may be chosen and set such that the product is less than the smallest cycle period of the expected motion patterns.
vs(min) is the norm of the minimum of the velocity within the interval t to t+m·dt. According to the second criterion (C2), if the velocity vs(t) at time t equals this minimum the algorithm will determine that the object is in a zero velocity state, if further the acceleration as(t) is less than a threshold af which depends on the time since the last determination of a zero velocity state and which also depends on the maximal velocity since the last zero velocity state.
Further, the first criterion comprises the sub-criteria that the acceleration as(t) equals the minimum of the acceleration within the interval t to t+m·dt denoted as as(min) and further the sub-criteria that the velocity vs(t) at time t is less than a velocity threshold vf which is dependent on the maximal velocity since the last determination of a zero velocity state and which also depends on the time since the last zero velocity state as the acceleration threshold af.
Further, the acceleration threshold af as well as the velocity threshold vf both increase with increasing maximal velocity since the last zero velocity state according to a polynomial of third order as expressed by the factor fv. By this dependency a number of different motion patterns like walking, running, ascending, descending or crawling may be modelled by a universal equation. The coefficients A, B and C may be learned by evaluating training data providing accelerations as well as actual zero velocity states. Further, by the time dependence of the velocity threshold vf and the acceleration threshold af expected cycle periods of different motion patterns may be taken into account, thereby relaxing the requirements (increasing the thresholds) as the time since the last zero velocity state increases.
In summary, according to an embodiment a zero velocity state is determined, if at least one of the first criterion C1 and the second criterion C2 is satisfied.
The first criterion C1 contains four subconditions, which must be satisfied simultaneously at time t:
First subcondition of criterion C1:as(t)=as(min)
The absolute value (as(t)) of the acceleration in direction of the movement at the time t, formed from n subsequently measured accelerations, has to be a minimum (as(min)). The minimum is derived within a range of m subsequent averages of accelerations. Typical values (for a measuring frequency of 100 Hz) for n lie between 3 and 5, typical values for m lie between 20 and 40.
Second subcondition of criterion C1:|vs(t)−vs(min)|<Δv*fv
The absolute value of the difference of the absolute value of the velocity in direction of motion at time t (vs(t)) and the absolute value of the minimal velocity (vs(min)) in a range of m subsequent velocities has to be smaller than a variable (fv) tolerance value (Δv). fv is calculated according to the equation fv=A*vmax3+B*vmax+C. The maximal velocity vmax thereby is the absolute value of the maximal velocity since the last zero velocity update. The parameters A, B, C may be determined from experiments. They depend on the typical motion pattern of the sensor carrier (the person carrying the sensor), the measuring accuracy, the soil conditions, etc. It is important to select them such that a spectrum of motion patterns as broad as possible (ideally all motion patterns) is covered (i.e. can be recognized or treated using the algorithm).
Third subcondition of criterion C1:vs(t)<vf
The absolute value of the velocity in direction of motion at time t (vs(t)) has to be smaller than a variable (fv*(1+Δt)) tolerance value (Δv). fv is calculated as in the former subcondition, except that the factor is now multiplied with a time dependent parameter (1+Δt). Δt is the time (in seconds) since the last zero velocity state.
Fourth subcondition of criterion C1:as(t-1)>as(t)
The absolute value (as(t-1)) of the average of the accelerations in direction of motion at time (t−1), formed from n subsequently measured accelerations, is greater than the acceleration at time t (as(t)).
The second criterion C2 contains two subconditions which must be simultaneously satisfied at time t.
First subcondition of criterion C2:vs(t)=vs(min)
The absolute value of the velocity in direction of motion at time t (vs(t)) has to be a minimum (vs(min)). The minimum is derived within a range of m subsequent absolute values of velocities. Thereby, m is identical to the value m used in the first and second subcondtions or criterion C1.
Second subcondition of criterion C2:as(t)<af
The absolute value (as(t)) of the average of the accelerations in direction of motion at time t, formed from n subsequently measured accelerations, has to be smaller than a variable (fv*(1+Δt)) tolerance value (Δa). fv* (1+Δt) corresponds to the factor used in the third subcondition of criterion C1.
In other embodiments one of more subconditions of the first criterion C1 and/or the second criterion C2 may be (slightly) altered or may even be omitted.
The curve 337 denotes the acceleration measured by the system 100 illustrated in
The zero velocity state determined solely based on the measured accelerations determined according to the criterion C* are denoted by reference sign 347. At these instances the velocity threshold vf (curve 343) as well as the acceleration threshold af (curve 339) are reset (reduced) to low values, because at these instances in time the time since the last determination of a zero velocity state is zero such that the quantity Δt in equations for vf and af above is zero. Further, at these instances of time 347 the velocity 341 is set to zero.
To the right of the instances 347 (zero velocity states determined according to criterion C*) the velocity threshold vf (curve 343) as well as the acceleration threshold af (curve 339) both increase as the time since the last zero velocity state increases and as the velocity 341 increases. Thus, it becomes more and more probable that the measured acceleration 337 falls below the threshold 339 and that the velocity 341 falls below the threshold 343. Thus, it becomes more and more probable that one of the criteria C1 or C2 is satisfied.
As can be observed from
Thus, the algorithm of the determination of the velocities according to the criterion C* performs very well for the motion pattern of walking. Similar results were achieved for other walking patterns, such as ascending, descending, running, or crawling. The good performance at different motion patterns may be attributed to the form of the factor fv taking into account a typical velocity, such as the maximum velocity, of each motion pattern. Thereby, a context sensitivity of the method may be achieved.
Further, the system 400 for determining a coordinate of an object may exchange the coordinate data with the update engine 451 which may check the determined coordinates and evaluate their plausibility. Depending on the plausibility the update engine may correct the coordinate data delivered by the system 400 for determining a coordinate of an object and send the corrected coordinates back to the system 400 illustrated in
The graphics display 453 may for example comprise a head-mounted display which is carried by the pedestrian, such as a fire fighter during the emergency operation. Further, the update engine 451 is connected to different data sources 455 and is also connected to a network 457 for transferring different kinds of information to a central server or a number of computers.
The CADMS illustrated in
The method for determining a coordinate of an object was evaluated in a number of experiments. Test trails having a length of more than 6 km in buildings with different construction characteristics and functions were used as test paths. The results, in combination with map matching algorithms, resulted in an accuracy of 1-2 m in the determination of the positions in buildings up to 95%. A particular challenge is met by the method and system according to an embodiment, since all calculations may be performed in real-time and only a low amount of data (the actual accurately determined coordinates of the object) must be sent to a base station or an update engine. The algorithm may for example be implemented within a smart phone which provides sufficient calculation capacity.
The methods and systems described above may in particular be applied when an inertial measurement unit is mounted at a foot of a pedestrian, since in this case the occurrence of an actual zero velocity state is expected whenever the pedestrian uses his feet for movement. However, the methods and systems may be adapted to be also applicable to cases where the inertial measurement unit is carried at other body parts of the human.
Number | Date | Country | Kind |
---|---|---|---|
EP 10162753.7 | May 2010 | EP | regional |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/EP11/57493 | 5/10/2011 | WO | 00 | 12/12/2012 |