1. Technical Field of the Invention
The present invention relates to a method of and apparatus for estimating an offset of a magnetic sensor.
2. Description of the Related Art
In recent years, a three-dimensional magnetic sensor is provided in a portable equipment, such as a portable phone, or a movable object, such as a car, for detecting geomagnetism. Generally, the three-dimensional magnetic sensor includes three magnetic sensor modules for dividing a vector of a magnetic field into components in three directions and detecting respective scalar quantities. The three-dimensional magnetic sensor outputs magnetic data, which are three-dimensional vector data having the scalar quantities output from the three magnetic sensor modules as three components.
Meanwhile, equipment, such as a portable telephone, equipped with the three-dimensional magnetic sensor often includes electric and magnetic parts, such as various kinds of metals that can be magnetized and electric circuits, generating a magnetic field. In this case, magnetic data output by the three-dimensional magnetic sensor also include a vector representing an internal magnetic field generated by the parts provided in the equipment in addition to a vector representing geomagnetism.
In order to correctly detect a value of the geomagnetism, therefore, it is necessary to perform a correction process of removing a vector representing a disturbance component, such as the internal magnetic field generated by the parts of the equipment, from the magnetic data output by the three-dimensional magnetic sensor. The disturbance component should be removed from the magnetic data output by the three-dimensional magnetic sensor through the correction process in order to obtain a correct value of the geomagnetism. Such a disturbance component is referred to as an offset of the three-dimensional magnetic sensor.
The internal magnetic field, which is generated by the parts of the equipment, is a magnetic field having a uniform direction and a uniform magnitude with respect to the equipment. In a case in which the internal magnetic field is found from the three-dimensional magnetic sensor provided in the equipment, therefore, the internal magnetic field is represented as a vector having a uniform direction and a uniform magnitude even when the equipment is placed in any attitude.
On the other hand, the geomagnetism is a magnetic field having a horizontal component directed to a north magnetic pole and a perpendicular component decided by a magnetic dip. The geomagnetism is a uniform magnetic field having a uniform direction and a uniform magnitude with respect to the ground. In a case in which the attitude of the equipment is changed with respect to the ground, therefore, the direction of the geomagnetism viewed from the equipment is also changed. That is, when viewed from the three-dimensional magnetic sensor provided in the equipment, the geomagnetism is represented as a vector having a direction changed as the attitude of the equipment is changed and a uniform magnitude.
Patent literature 1 discloses a method of separating between geomagnetism and internal magnetic field. By using properties of geomagnetism and internal magnetic field, the disclosed method divides a plurality of magnetic data acquired while changing the attitude of equipment, i.e. the attitude of a three-dimensional magnetic sensor into a component representing the internal magnetic field having a uniform direction and magnitude when viewed from the magnetic sensor and a component representing the geomagnetism having a direction changed as the attitude of the three-dimensional magnetic sensor is changed and a uniform magnitude, and calculates the divided component representing the internal magnetic field as an offset.
In a case in which the offset of the three-dimensional magnetic sensor is calculated using the conventional method, however, it is necessary to acquire a plurality of magnetic data while sufficiently changing the attitude of the three-dimensional magnetic sensor. In a case in which the attitude of the three-dimensional magnetic sensor is not sufficiently changed, therefore, it is not possible to accurately calculate the offset.
The present invention has been made in view of the above problem, and it is an object of the present invention to provide an offset estimation method and apparatus that is capable of estimating an offset even when the change in attitude of a three-dimensional magnetic sensor is smaller than the change in attitude of the three-dimensional magnetic sensor necessary in a case in which the offset is calculated using the conventional method.
In order to solve the above problems, the present invention provides a method of estimating an offset of a magnetic sensor that is provided in equipment for detecting magnetism including geomagnetism, the equipment having an angular velocity sensor for detecting an angular velocity of the equipment. The inventive method comprises: calculating attitude data representing an attitude variation of the equipment from a reference attitude thereof based on angular velocity data that is outputted from the angular velocity sensor and that represents the detected angular velocity of the equipment; and calculating an estimation value of the offset minimizing an error between a predetermined number of first variable vectors associated to a predetermined number of the attitude data that are successively calculated in response to the angular velocity data outputted from the angular velocity sensor and a predetermined number of second variable vectors associated to a predetermined number of the magnetic data that are successively outputted from the magnetic sensor and that represent the detected magnetism including the geomagnetism. The first variable vector is obtained by changing a reference variable vector in accordance with the attitude variation represented by the attitude data, the reference variable vector representing the geomagnetism when the equipment is placed in the reference attitude, and the second variable vector is obtained by subtracting the estimation value of the offset from the magnetic data.
The offset estimation method according to the present invention calculates the estimation value of the offset based on the magnetic data and the angular velocity data. The angular velocity data are data representing the change in attitude of the equipment. In the angular velocity data, the change in attitude of the equipment is correctly represented.
In a case in which the attitude of the equipment is changed, the attitude change is expressed as distribution of a plurality of points indicated by a plurality of magnetic data output from the three-dimensional magnetic sensor in the three-axis rectangular coordinate system for expressing the detection result of the three-dimensional magnetic sensor. And the estimation value of the offset of the three-dimensional magnetic sensor is calculated using a statistical method based on the distribution shape of the points. That is, the estimation value of the offset of the three-dimensional magnetic sensor is calculated based on the distribution shape of a plurality of points set based on the change in attitude of the equipment. If it is possible to correctly detect the change in attitude of the equipment and to correctly reflect the detection result with respect to calculation to calculate the estimation value of the offset, therefore, it is possible to accurately calculate the estimation value of the offset.
The offset estimation method according to the present invention calculates the estimation value of the offset based on the angular velocity data in addition to the magnetic data. Consequently, it is possible for the offset estimation method according to the present invention to correctly reflect the change in attitude of the equipment with respect to calculation to calculate the estimation value of the offset as compared with a case in which the estimation value of the offset is calculated based only on the magnetic data. As a result, it is possible for the offset estimation method to accurately calculate the estimation value of the offset even in a case in which the change in attitude of the equipment is small.
Specifically, the estimation value of the offset is calculated as an offset variable vector that minimizes an objective function representing the error between the predetermined number of the first variable vectors and the predetermined number of the second variable vectors.
Preferably, the inventive method further comprises: determining whether or not a degree of difference between a distribution shape of a predetermined number of points indicated by the predetermined number of the first variable vectors and a distribution shape of a predetermined number of points indicated by the predetermined number of the second variable vectors is within a predetermined range; and adopting the estimation value of the offset as the offset of the magnetic sensor in case that the degree of the difference is determined to be within the predetermined range.
Preferably, the inventive method further comprises: determining whether or not a degree of difference between components of an estimated geomagnetic data distribution matrix representing distribution of the predetermined number of the first variable vectors and components of a magnetic data distribution matrix representing distribution of the predetermined number of the magnetic data is within a predetermined range; and adopting the estimation value of the offset as the offset of the magnetic sensor in case that the degree of the difference is determined to be within the predetermined range.
Preferably, the inventive method further comprises: generating an accuracy index representing accuracy of calculation for calculating the estimation value of the offset; and determining whether or not the accuracy index is equal to or greater than a predetermined threshold value, wherein the estimation value of the offset is calculated in case that the accuracy index is determined to be equal to or greater than the predetermined threshold value, and the estimation value of the offset is not calculated in case that the accuracy index is determined to be less than the predetermined threshold value.
Preferably, the error is represented by a function using variables including elements of the reference variable vector and elements of an offset variable vector representing the estimation value of the offset, and the accuracy index is a minimum eigenvalue of a coefficient matrix that is given by expressing the error in a quadratic form based on the variables.
Preferably, the predetermined threshold value is a positive real number.
In addition, the present invention further provides an apparatus for estimating an offset of a magnetic sensor that is provided in equipment for detecting magnetism including geomagnetism, the equipment having an angular velocity sensor for detecting an angular velocity of the equipment, the apparatus comprising one or more processors configured to: calculate attitude data representing an attitude variation of the equipment from a reference attitude thereof based on angular velocity data that is outputted from the angular velocity sensor and that represents the detected angular velocity of the equipment; and calculate an estimation value of the offset minimizing an error between a predetermined number of first variable vectors associated to a predetermined number of the attitude data that are successively calculated in response to the angular velocity data outputted from the angular velocity sensor and a predetermined number of second variable vectors associated to a predetermined number of the magnetic data that are successively outputted from the magnetic sensor and that represent the detected magnetism including the geomagnetism, wherein the first variable vector is obtained by changing a reference variable vector in accordance with the attitude variation represented by the attitude data, the reference variable vector representing the geomagnetism when the equipment is placed in the reference attitude, and the second variable vector is obtained by subtracting the estimation value of the offset from the magnetic data.
Specifically, the estimation value of the offset is calculated as an offset variable vector that minimizes an objective function representing the error between the predetermined number of the first variable vectors and the predetermined number of the second variable vectors.
Preferably, the one or more processors of the inventive apparatus are further configured to: determine whether or not a degree of difference between a distribution shape of a predetermined number of points indicated by the predetermined number of the first variable vectors and a distribution shape of a predetermined number of points indicated by the predetermined number of the second variable vectors is within a predetermined range; and adopt the estimation value of the offset as the offset of the magnetic sensor in case that the degree of the difference is determined to be within the predetermined range.
Preferably, the one or more processors of the inventive apparatus are further configured to: determine whether or not a degree of difference between components of an estimated geomagnetic data distribution matrix representing distribution of the predetermined number of the first variable vectors and components of a magnetic data distribution matrix representing distribution of the predetermined number of the magnetic data is within a predetermined range; and adopt the estimation value of the offset as the offset of the magnetic sensor in case that the degree of the difference is determined to be within the predetermined range.
Preferably, the one or more processors of the inventive apparatus are further configured to: generate an accuracy index representing accuracy of calculation for calculating the estimation value of the offset; and determine whether or not the accuracy index is equal to or greater than a predetermined threshold value, wherein the estimation value of the offset is calculated in case that the accuracy index is determined to be equal to or greater than the predetermined threshold value, and the estimation value of the offset is not calculated in case that the accuracy index is determined to be less than the predetermined threshold value.
Preferably, the error is represented by a function using variables including elements of the reference variable vector and elements of an offset variable vector representing the estimation value of the offset, and the accuracy index is a minimum eigenvalue of a coefficient matrix that is given by expressing the error in a quadratic form based on the variables. Preferably, the predetermined threshold value is a positive real number.
A first embodiment of the present invention will be described with reference to the accompanying drawings.
The portable equipment 1 includes a CPU 10 connected to various kinds of configuration elements via buses for controlling the entirety of the apparatus, a RAM (accumulation unit) 20 functioning as a work area of the CPU 10, a ROM 30 for storing various kinds of programs, such as an offset estimation program 200 and data, a display unit 40 for displaying various kinds of information, and a communication unit (not shown) for performing communication.
In addition, the portable equipment 1 includes a three-dimensional magnetic sensor 50 for detecting a magnetic field, such as geomagnetism, on a unit time Δt basis, to output magnetic data M and a three-dimensional angular velocity sensor 60 for detecting angular velocity on a unit time Δt basis to periodically output angular velocity data W.
For example, the display unit 40 may display a direction of geomagnetism Bg estimated by the portable equipment 1 based on the magnetic data M and the angular velocity data W as an image such an arrow.
The three-dimensional magnetic sensor 50 includes an X axis magnetic sensor 51, a Y axis magnetic sensor 52, and a Z axis magnetic sensor 53. Each of the sensors may be configured using a magnetic impedance device (MI device), a magnetic resistance effect device (MR device), etc. A magnetic sensor I/F 54 converts analog output signals from the X axis magnetic sensor 51, the Y axis magnetic sensor 52, and the Z axis magnetic sensor 53 into digital signals to output magnetic data M. The magnetic data M are data representing a magnetic vector m, which is a three-dimensional vector represented by an x axis component, a y axis component, and a z axis component. More specifically, in a three-axis rectangular coordinate system fixed to the three-dimensional magnetic sensor 50 (hereinafter, referred to as a sensor coordinate system ΣS), the magnetic vector m is a three-dimensional vector representing an output value from the X axis magnetic sensor 51 as an x axis component, an output value from the Y axis magnetic sensor 52 as a y axis component, and an output value from the Z axis magnetic sensor 53 as a z axis component.
Meanwhile, hereinafter, magnetic data M output based on a magnetic field detected by the three-dimensional magnetic sensor 50 at a time T=k will be expressed as magnetic data Mk obtained by attaching a subscript k to the magnetic data M and a three-dimensional vector represented by the magnetic data Mk will be expressed as a magnetic vector mk.
A magnetic field detected by the three-dimensional magnetic sensor 50 includes geomagnetism Bg and an internal magnetic field Bi. Hereinafter, properties of the geomagnetism Bg and the internal magnetic field Bi will be described with reference to
Generally, the geomagnetism Bg is a magnetic field having a horizontal component directed to a north magnetic pole and a perpendicular component decided by a magnetic dip. The geomagnetism Bg is represented as a vector GBg having a uniform direction and magnitude in the ground coordinate system ΣG (Meanwhile, hereinafter, a superscript G attached to the left upper part of a symbol of a vector means that the vector is represented in the ground coordinate system ΣG). That is, the direction and magnitude of the vector GBg representing the geomagnetism Bg are not changed even when the attitude A and the position P of the portable equipment 1 are changed.
The internal magnetic field Bi is a magnetic field having a uniform direction and a uniform magnitude when viewed from the portable equipment 1. For example, the internal magnetic field Bi is a magnetic field generated by a physical component contained in the portable equipment 1. For this reason, a vector representing the internal magnetic field Bi in ground coordinate system ΣG is a vector, the direction of which is changed according to change in the attitude A of the portable equipment 1, and may be expressed as a vector GBi(A), which is a function of the attitude A.
In the sensor coordinate system ΣS, the internal magnetic field Bi is represented as a vector SBi having a uniform direction and magnitude even when the attitude A and the position P of the portable equipment 1 are changed (That is, a superscript S attached to the left upper part of a symbol of a vector means that the vector is represented in sensor coordinate system ΣS).
In the sensor coordinate system ΣS, the geomagnetism Bg is represented as a vector SBg(A) having a direction varying according to the attitude A of the portable equipment 1 and a uniform magnitude. The vector SBg(A) represents a direction of the geomagnetism Bg when viewed from the sensor coordinate system ΣS, i.e. a direction of the geomagnetism Bg when viewed from the portable equipment 1.
In a case in which the three-dimensional magnetic sensor 50 detects only the geomagnetism Bg and the internal magnetic field Bi, the magnetic vector m represents the sum of the geomagnetism Bg and the internal magnetic field Bi. That is, in this case, the magnetic vector m in the sensor coordinate system ΣS represents the sum of the vector SBi and the vector SBg(A).
In a case in which the vector SBi is positioned such that the start point (the initial point) of the vector SBi coincides with the origin of the sensor coordinate system ΣS, the end point of the vector SBi is given as a point CG. In addition, a spherical surface having the point CG as a center and the magnitude of the geomagnetism Bg as a radius is given as a spherical surface Sg.
At this time, when a magnetic field is measured while the attitude A of the portable equipment 1 is changed from A1 to AN, a plurality of magnetic vectors m1 to mN represented by a plurality of magnetic data M1 to MN output from the three-dimensional magnetic sensor 50 indicates coordinates on the spherical surface Sg as shown in
A process of subtracting the coordinates indicated by the center point CG of the spherical surface Sg from the coordinates indicated by the magnetic vector mk to acquire a correct direction of the geomagnetism Bg, which is a target to be detected, as described above is referred to as a correction process. In addition, a vector to be removed from the magnetic vector mk through the correction process is referred to as an offset cOFF of the three-dimensional magnetic sensor 50. In an example shown in
Meanwhile, since the magnetic data M output by the three-dimensional magnetic sensor 50 has a measurement error in a practical sense, the points represented by the magnetic vectors m1 to mN are stochastically distributed in the vicinity of the spherical surface Sg in a narrow sense.
Referring back to
Meanwhile, hereinafter, angular velocity data W output based on an angular velocity detected by the three-dimensional angular velocity sensor 60 at a certain time T=k will be expressed as angular velocity data Wk obtained by attaching a subscript k to the angular velocity data W and a three-dimensional vector represented by the angular velocity data Wk will be expressed as an angular velocity vector ωk.
The CPU 10 executes the offset estimation program 200 stored in the ROM 30 to estimate the offset cOFF of the three-dimensional magnetic sensor 50. That is, since the CPU 10 executes the offset estimation program 200, the CPU 10 functions as an offset estimation apparatus 100.
The offset estimation apparatus 100 includes an attitude calculation unit 110, an accuracy determination unit 130, an offset calculation unit 140, a distribution shape determination unit 150, and an adoption unit 160.
The offset estimation apparatus 100 generates an estimation value cE of the offset cOFF of the three-dimensional magnetic sensor 50 based on the magnetic data M and the angular velocity data W. More specifically, the offset estimation apparatus 100 generates an estimation value CE of the offset cOFF based on magnetic vectors m1 to mN and angular velocity vectors ω1 to ωN represented by N magnetic data M1 to MN and N angular velocity data W1 to WN respectively output from the three-dimensional magnetic sensor 50 and the three-dimensional angular velocity sensor 60 on a unit time Δt basis from a time T=1 to a time T=N.
Meanwhile, the three-dimensional magnetic sensor 50, the three-dimensional angular velocity sensor 60, and a memory unit 300 are also shown in the function block diagram of
In addition, hereinafter, the distribution shape determination unit 150 will also be referred to as a first determination unit and the accuracy determination unit 130 will also be referred to as a second determination unit.
The attitude calculation unit 110 calculates an attitude variation of an attitude Ak of the portable equipment 1 at each time T=k (k=1, 2, . . . , N) from a reference attitude (attitude A1), which is an attitude A1 of the portable equipment 1 at a time T=1, based on an angular velocity vector ω indicated by angular velocity data W output from the three-dimensional angular velocity sensor 60 and periodically outputs attitude data, which are data representing the calculated attitude variation.
In this embodiment, the attitude A and the attitude variation are expressed using a rotation matrix of 3×3 (for example, direct cosine matrix). Hereinafter, a rotation matrix representing an attitude variation from the reference attitude (attitude A1) to the attitude Ak will be referred to as an attitude rotation matrix Rk.
The attitude calculation unit 110 calculates an attitude rotation matrix Rk at each time T=k (k=1, 2, . . . , N) based on Equation (1) and Equation (2) below and outputs the calculated attitude rotation matrix Rk. Meanwhile, a matrix I3×3 present in Equation (1) is a unit matrix of 3×3. In addition, an operator Ω present in Equation (2) is an operator for converting a three-dimensional vector p shown in Equation (4) into an alternating matrix of 3×3 present at the right side of Equation (3) as shown in Equation (3).
Although, in this embodiment, the attitude A1 is a reference attitude, the reference attitude is not particularly restricted so long as an attitude variation of an attitude Ak at each time T=k (k=1, 2, . . . , N) from the reference attitude can be calculated based on angular velocity data W.
For example, the reference attitude may be any one of the attitude A2 to the attitude AN.
The N attitude data (that is, N attitude rotation matrices R1 to RN) generated by the attitude calculation unit 110 are stored in the memory unit 300. The memory unit 300 corresponds to the RAM 20 shown in
In addition, the N magnetic data M1 to MN (that is, N magnetic vectors m1 to mN) output from the three-dimensional magnetic sensor 50 are also stored in the memory unit 300 in addition to the N attitude rotation matrices R1 to RN.
The accuracy determination unit 130 performs an accuracy determination process using the attitude rotation matrices R1 to RN stored in the memory unit 300.
The accuracy determination process is a process of determining whether or not, in a case in which the offset calculation unit 140 calculates an estimation value cE of the offset cOFF based on the attitude rotation matrices R1 to RN and the magnetic vectors m1 to mN stored in the memory unit 300, accuracy of the calculation is high. The accuracy determination process will hereinafter be described in detail.
In a case in which the result of the determination performed by the accuracy determination unit 130 is positive, the offset calculation unit 140 calculates an estimation value cE of the offset cOFF and a reference estimated geomagnetic vector rE1 based on the attitude rotation matrices R1 to RN and the magnetic vectors m1 to mN stored in the memory unit 300. Meanwhile, the reference estimated geomagnetic vector rE1 will hereinafter be described.
Meanwhile, the process of calculating the estimation value cE of the offset cOFF performed by the offset calculation unit 140 may also be referred to as an offset calculation process.
The distribution shape determination unit 150 performs a distribution determination process using the attitude rotation matrices R1 to RN and the magnetic vectors m1 to mN stored in the memory unit 300 and the reference estimated geomagnetic vector rE1 calculated by the offset calculation unit 140.
The distribution determination process is a process of determining whether or not, in a case in which the offset calculation unit 140 calculates an estimation value CE of the offset cOFF based on the attitude rotation matrices R1 to RN and the magnetic vectors m1 to mN stored in the memory unit 300, the estimation value cE of the offset cOFF calculated by the offset calculation unit 140 correctly represents the offset cOFF. The distribution determination process will hereinafter be described in detail.
In a case in which the result of the determination performed by the distribution shape determination unit 150 is positive, the adoption unit 160 adopts the estimation value cE of the offset cOFF calculated by the offset calculation unit 140 as the offset cOFF. In a case in which the result of the determination performed by the distribution shape determination unit 150 is negative, the adoption unit 160 does not adopt the estimation value cE as the offset cOFF.
Although, in this embodiment, the offset calculation unit 140 calculates the estimation value cE of the offset cOFF and the reference estimated geomagnetic vector rE1 only in a case in which the result of the determination performed by the accuracy determination unit 130 is positive, the present invention is not limited to this embodiment.
For example, the offset calculation unit 140 may calculate the estimation value cE of the offset cOFF or else irrespective of the result of the determination performed by the accuracy determination unit 130. In this case, the adoption unit 160 may adopt the estimation value cE of the offset cOFF calculated by the offset calculation unit 140 as the offset cOFF only in a case in which the result of the determination performed by the accuracy determination unit 130 is positive and the result of the determination performed by the distribution shape determination unit 150 is positive.
Hereinafter, the offset calculation process, the distribution determination process, and the accuracy determination process as described above will be described in detail.
As described above, the offset calculation process performed by the offset calculation unit 140 is a process of calculating an estimation value cE of the offset cOFF. First, the offset calculation process performed by the offset calculation unit 140 will hereinafter be described in detail.
As shown in
S
B
g(Ak)=mk−cOFF (k=1, . . . , N) Equation (5)
S
B
g(Ak)=rk=RkTr1 (k=1, . . . , N) Equation (6)
m
k
=R
k
T
r
1
+c
OFF (k=1, . . . , N) Equation (7)
Meanwhile, Equation (7) comes into effect only in an ideal case, i.e. in a case in which the three-dimensional magnetic sensor 50 can detect a magnetic field without an error and, in addition, the magnetic vector mk output from the three-dimensional magnetic sensor 50 completely coincides with the detected magnetic field. In a case in which Equation (7) comes into effect, therefore, it is possible to calculate the offset cOFF as a solution of a simultaneous linear equation set by Equation (7).
However, the magnetic data M output from the three-dimensional magnetic sensor 50 have a measurement error and, generally, the left side and the right side of Equation (7) do not coincide with each other. For this reason, it is not possible to calculate the offset cOFF as the solution of the simultaneous linear equation set based on Equation (7).
In the offset calculation process according to this embodiment, therefore, an objective function f(x) shown in Equation (8) below is introduced to calculate an estimation value (approximate value) of the offset cOFF and an estimation value (approximate value) of the reference observed geomagnetic vector r1 using a statistical method such that the left side and the right side of Equation (7) have as approximate values as possible.
The objective function f(x) is a function representing a degree of error magnitude between first variable vectors g1 to gN and second variable vectors d1 to dN. Specifically, the objective function f(x) represents an average of squared values of the magnitudes of vectors obtained by subtracting the second variable vectors dk from the first variable vectors gk as represented by Equation (8) below.
Here, a variable vector x, which is a variable of the objective function f(x), is a six-dimensional variable vector having a three-dimensional variable vector c representing the offset cOFF (hereinafter, also referred to as an offset variable vector c) and a three-dimensional variable vector r representing the reference observed geomagnetic vector r1 (hereinafter, also referred to as a reference variable vector r) as elements as represented by Equation (9) below. Namely, the objective function may be a function having, as a variable, a variable vector including each element of a reference variable vector, which is a variable representing the geomagnetism in the rectangular coordinate system when the attitude of the equipment is the reference attitude and each element of the offset variable vector as elements. In addition, the first variable vector gk is a three-dimensional variable vector representing the vector SBg(Ak) as represented by Equation (10). Namely, a variable representing the geomagnetism in the rectangular coordinate system when the attitude of the equipment is the reference attitude may be defined as a reference variable vector and the first variable vector may be a vector representing the reference variable vector in the rectangular coordinate system when the attitude of the equipment is changed from the reference attitude by the attitude variation. In addition, the second variable vectors dk is a three-dimensional variable vector representing the vector obtained by subtracting the offset variable vector c from the magnetic vector mk as represented by Equation (11).
It is possible to calculate a value considerable (plausible) as the offset cOFF and a value considerable (plausible) as the reference observed geomagnetic vector r1 by calculating the variable vector x minimizing such an objective function f(x) (that is, the offset variable vector c and the reference variable vector r to minimize the objective function f(x)).
Meanwhile, hereinafter, a vector obtained by adding the offset variable vector c to the first variable vector gk will also be referred to as a detected magnetic variable vector.
Hereinafter, a method of calculating the variable vector x minimizing the objective function f(x) represented by Equation (8) will be described in detail.
In this embodiment, first, the objective function f(x) is converted into an objective function g(x) represented by Equation (12) below. The objective function g(x) is a function obtained by expressing the objective function f(x) in a quadratic form having each element of the variable vector x as a variable and, in addition, deleting a constant term which does not affect minimization of the objective function f(x). The variable vector x minimizing such an objective function g(x) is equivalent to the variable vector x minimizing the objective function f(x). That is, minimization of the objective function f(x) may result in minimization of the objective function g(x).
Here, a matrix Q present in Equation (12) is a coefficient matrix of the objective function g(x), which is a quadratic form. Specifically, the matrix Q is a positive definite symmetric matrix of 6×6 represented by Equation (13). A vector b present in Equation (12) is a six-dimensional vector represented by Equation (15). A matrix RAVE present in Equation (13) is a matrix of 3×3 represented by Equation (14). A vector bR present in Equation (15) is a three-dimensional vector represented by Equation (16). A vector m present in Equation (15) is a three-dimensional vector represented by Equation (17).
Hereinafter, the variable vector x minimizing the objective function g(x) represented by Equation (12) will also be referred to as an optimal solution xOPT. In a case in which Equation (13) is a positive definite matrix, the optimal solution xOPT may be calculated by Equation (18) below. In addition, the optimal solution xOPT has the reference estimated geomagnetic vector rE1 and the estimation value cE of the offset cOFF as elements as represented by Equation (19) below. Here, the reference estimated geomagnetic vector rE1 is an estimation value of the reference geomagnetic vector r1.
Consequently, it is possible for the offset calculation unit 140 to calculate the estimation value cE of the offset cOFF by extracting an element corresponding to the estimation value cE represented by Equation (19) from the optimal solution xOPT calculated by Equation (18).
x
OPT
=Q
−1
b Equation (18)
x
OPT
=[e
E1
T
c
E
T]T Equation (19)
Meanwhile, in a case in which the result of the determination performed by the accuracy determination unit 130, which will hereinafter be described, is negative, the offset calculation unit 140 does not perform the above operations, i.e. a series of operations to calculate the estimation value cE of the offset.
In conclusion, the offset calculation process is a process of: setting a predetermined number of vectors representing geomagnetism when the attitude of the equipment is changed from the reference attitude to a predetermined number of attitudes in the rectangular coordinate system based on angular velocity data; setting a predetermined number of vectors (not including an offset) representing a predetermined number of geomagnetisms corresponding to change of the attitude based on magnetic data; and diminishing errors of the predetermined vectors representing the respective geomagnetisms to calculate the offset.
The present invention may also provide an offset estimation apparatus provided at equipment including a three-dimensional angular velocity sensor for periodically detecting angular velocities in three directions and for sequentially outputting detection results as angular velocity data and a three-dimensional magnetic sensor for periodically detecting magnetic components in three directions including geomagnetism and for sequentially outputting detection results as magnetic data, which are vector data in a three-axis rectangular coordinate system, to calculate an estimation value of an offset of the three-dimensional magnetic sensor, wherein the offset estimation apparatus includes an attitude calculation unit for periodically calculating an attitude variation of the equipment from a reference attitude based on the angular velocity data, a variable vector representing the geomagnetism in the rectangular coordinate system when the attitude of the equipment is the reference attitude being defined as a reference variable vector, a vector obtained by changing the reference variable vector by the attitude variation being defined as a first variable vector, a variable vector obtained by adding the first variable vector to an offset variable vector, which is a variable vector representing the offset, being defined as a detected magnetic variable vector, and an offset calculation unit for calculating the offset variable vector minimizing an error between a predetermined number of points in the rectangular coordinate system indicated by a predetermined number of the detected magnetic variable vectors respectively corresponding to a predetermined number of the attitude variations calculated by the attitude calculation unit and a predetermined number of points in the rectangular coordinate system indicated by a predetermined number of magnetic data output from the three-dimensional magnetic sensor as the estimation value of the offset.
Next, the distribution determination process will be described.
As previously described, the distribution determination process performed by the distribution shape determination unit 150 is a process of determining whether or not, in a case in which the offset calculation unit 140 calculates an estimation value cE of the offset cOFF based on the magnetic vectors m1 to mN stored in the memory unit 300, the estimation value cE correctly represents the offset cOFF. In other words, the distribution determination process is a process of determining whether or not the magnetic vectors m1 to mN stored in the memory unit 300 are data suitable for calculating the estimation value cE of the offset cOFF.
The offset calculation process as described above is a process performed on the premise that corrected magnetic vectors r1 to rN are vectors of equal length having the point CG as the start point (the initial point) in the sensor coordinate system ΣS as shown in
In a practical sense, however, the distribution shape of a plurality of points on the sensor coordinate system ΣS indicated by the magnetic vectors m1 to mN may be a distorted shape different from a spherical surface. In this case, even if the offset calculation unit 140 calculates an estimation value cE of the offset cOFF based on the magnetic vectors m1 to mN, there is a high possibility that the estimation value cE may be a value greatly deviating from the offset cOFF.
For example, as shown in
And even in a case in which a plurality of points on the sensor coordinate system ΣS indicated by the magnetic vectors m1 to mN is distributed in the vicinity of the surface of the solid SD having a shape different from the spherical surface like as in an example shown in
In a practical sense, however, the magnetic vectors m1 to mN shown in
That is, in a case in which a plurality of points on the sensor coordinate system ΣS indicated by the magnetic vectors m1 to mN is distributed in the vicinity of the surface of the solid SD, there is a high possibility that the estimation value cE calculated as the coordinates of the center point Cs of the spherical surface S may not correctly represent the offset cOFF.
For this reason, the distribution shape determination unit 150 determines whether or not the distribution shape of a plurality of points on the sensor coordinate system ΣS indicated by the magnetic vectors m1 to mN can be regarded as a spherical surface (that is, whether the distribution shape is not a distorted shape) based on the magnetic vectors m1 to mN, the attitude rotation matrices R1 to RN, and the reference estimated geomagnetic vector rE1 calculated by the offset calculation unit 140 to determine whether or not the estimation value cE of the offset cOFF calculated by the offset calculation unit 140 based on magnetic vectors m1 to mN correctly represents the offset cOFF.
As a result, in a case in which the offset calculation unit 140 calculates the estimation value cE of the offset cOFF based on the magnetic vectors m1 to mN not suitable for calculating the estimation value cE of the offset cOFF, i.e. the magnetic vectors m1 to mN containing noise, it is possible to determine that the calculated value does not correctly represent the offset cOFF.
Hereinafter, the distribution determination process performed by the distribution shape determination unit 150 will be described in detail.
As shown in
The first matrix calculation unit 152 calculates a matrix S represented by Equation (20) below based on the magnetic vectors m1 to mN stored in the memory unit 300. Here, a vector sk present in Equation (20) is a three-dimensional vector represented by Equation (21) below and the matrix S is a symmetric matrix of 3×3 represented by Equation (21) below showing distribution of the magnetic vectors m1 to mN in the sensor coordinate system ΣS. Hereinafter, the matrix S will also be referred to as a magnetic data distribution matrix.
The second matrix calculation unit 154 calculates a matrix E represented by Equation (25) below based on the attitude rotation matrices R1 to RN stored in the memory unit 300 and the reference estimated geomagnetic vector rE1 calculated by the offset calculation unit 140.
Specifically, first, the reference estimated geomagnetic vector rE1 is rotated according to the attitude rotation matrix Rk to calculate an estimated geomagnetic vector rEk, which is a three-dimensional vector, as represented by Equation (22) below. Next, an average of estimated geomagnetic vectors rE1 to rEN is calculated to calculate a vector rEAVE, which is a three-dimensional vector, as represented by Equation (23) below. In addition, a vector ek, which is a three-dimensional vector, based on the vector rEAVE and the estimated geomagnetic vector rEk as represented by Equation (24) below. And a matrix E, which is a symmetric matrix of 3×3, is calculated based on the vector ek as represented by Equation (25) below.
Here, the matrix E is a matrix representing distribution of the estimated geomagnetic vector rEk as obvious from Equation (23) to Equation (25) below. Hereinafter, the matrix E will also be referred to as an estimated geomagnetic data distribution matrix.
In a case in which the influence of the noise magnetic field Bx is negligibly small, a point on the sensor coordinate system ΣS indicated by a vector obtained by adding the vector representing the estimation value cE of the offset cOFF to the reference estimated geomagnetic vector rE1 can be regarded as coinciding with a point on the sensor coordinate system ΣS indicated by the magnetic vector m1.
In addition, the estimated geomagnetic vector rEk is an estimation value (approximate value) of the observed geomagnetic vector rk, which is a vector obtained by rotating the reference estimated geomagnetic vector rE1, which is an estimation value of the reference observed geomagnetic vector r1, according to the attitude rotation matrix Rk and a vector obtained by rotating the reference observed geomagnetic vector r1 according to the attitude rotation matrix Rk. In a case in which the influence of the noise magnetic field Bx is negligibly small, therefore, a point on the sensor coordinate system ΣS indicated by a vector obtained by adding the vector representing the estimation value cE of the offset cOFF to the estimated geomagnetic vector rEk can be regarded as coinciding with a point on the sensor coordinate system ΣS indicated by the magnetic vector mk.
That is, if the influence of the noise magnetic field Σx is negligibly small and the distribution shape of a plurality of points on the sensor coordinate system ΣS indicated by the magnetic vectors m1 to mN can be regarded as a spherical surface, the distribution shape of a plurality of points on the sensor coordinate system ΣS indicated by the estimated geomagnetic vectors rE1 to rEN can be regarded as coinciding with the distribution shape of a plurality of points on the sensor coordinate system ΣS indicated by the magnetic vectors m1 to mN.
In addition, in a case in which the influence of the noise magnetic field Bx is large, there is a high possibility that the distribution shape of a plurality of points on the sensor coordinate system ΣS indicated by the magnetic vectors m1 to mN may be a distorted shape different from a spherical surface. Even in this case, on the other hand, the distribution shape of a plurality of points on the sensor coordinate system ΣS indicated by the estimated geomagnetic vectors rE1 to rEN is a spherical surface.
That is, in a case in which the influence of the noise magnetic field Bx is negligibly small, the distribution shape of a plurality of points on the sensor coordinate system ΣS indicated by the estimated geomagnetic vectors rE1 to rEN can be regarded as coinciding with the distribution shape of a plurality of points on the sensor coordinate system ΣS indicated by the magnetic vectors m1 to mN. In a case in which the influence of the noise magnetic field Bx is large, however, the two distribution shapes are different from each other.
Consequently, it is possible to estimate a degree of influence of the noise magnetic field Bx based on a degree of difference between the distribution shape of a plurality of points on the sensor coordinate system ΣS indicated by the estimated geomagnetic vectors rE1 to rEN and the distribution shape of a plurality of points on the sensor coordinate system ΣS indicated by the magnetic vectors m1 to mN. That is, it is possible to determine whether or not the estimation value cE of the offset cOFF calculated by the offset calculation unit 140 correctly represents the offset cOFF by determining whether or not a degree of difference between the two distribution shapes is within a predetermined range, i.e. the two distribution shapes can be regarded as coinciding with each other.
Meanwhile, determination as to whether or not a degree of difference between the distribution shape of a plurality of points on the sensor coordinate system ΣS indicated by the estimated geomagnetic vectors rE1 to rEN and the distribution shape of a plurality of points on the sensor coordinate system ΣS indicated by the magnetic vectors m1 to mN is within a predetermined range may be performed using any method.
In this embodiment, as an example, determination as to whether or not the two distribution shapes can be regarded as coinciding with each other is performed by determining whether or not the matrix E and the matrix S can be regarded as coinciding with each other.
Specifically, the similarity determination unit 156 determines whether or not a degree of difference between a component of the matrix E representing distribution of the estimated geomagnetic vector rEk and a component of the matrix S representing distribution of the magnetic vectors m1 to mN is within a predetermined range (determines whether or not the matrix E and the matrix S coincide with each other or are similar to each other) to determine whether or not a degree of difference between the distribution shape of a plurality of points on the sensor coordinate system ΣS indicated by the estimated geomagnetic vectors rE1 to rEN and the distribution shape of a plurality of points on the sensor coordinate system ΣS indicated by the magnetic vectors m1 to mN is within a predetermined range and thus to determine whether or not the estimation value cE of the offset cOFF calculated by the offset calculation unit 140 correctly represents the offset cOFF.
Hereinafter, a specific determination method will be described.
Three eigenvalues of the matrix E are defined as a maximum eigenvalue λE, MAX, a middle eigenvalue λE, MID, and a minimum eigenvalue λE, MIN in order of size and three normalized eigenvectors corresponding to the respective eigenvalues are defined as an eigenvector uE, MAX, an eigenvector uE, MID, and an eigenvector uE, MIN.
In addition, three eigenvalues of the matrix S are defined as a maximum eigenvalue λS, MAX, a middle eigenvalue λS, MID, and a minimum eigenvalue λS, MIN in order of size and three normalized eigenvectors corresponding to the respective eigenvalues are defined as an eigenvector uS, MAX, an eigenvector uS, MID, and an eigenvector uS, MIN.
In a case in which the matrix E and the matrix S can be regarded as coinciding with each other, the maximum eigenvalue λE, MAX, the middle eigenvalue λE, MID, and the minimum eigenvalue λE, MIN can be regarded as being equivalent to the maximum eigenvalue λS, MAX, the middle eigenvalue λS, MID, and the minimum eigenvalue λS, MIN, respectively. In addition, the eigenvector uE, MAX, the eigenvector uE, MID, and the eigenvector uE, MIN can be regarded as being equivalent to the eigenvector uS, MAX, the eigenvector uS, MID, and the eigenvector uS, MIN, respectively.
That is, in a case in which the matrix E and the matrix S satisfy a first determination condition represented by Equation (26) below, a second determination condition represented by Equation (27) below, a third determination condition represented by Equation (28) below, a fourth determination condition represented by Equation (29) below, a fifth determination condition represented by Equation (30) below, and a sixth determination condition represented by Equation (31) below, the matrix E and the matrix S can be regarded as coinciding with each other.
Here, a first threshold value α1, a second threshold value α2, and a third threshold value α3 present in Equation (26) to Equation (28) are real numbers greater than 0 and less than 1 and a fourth threshold value α4, a fifth threshold value α5, and a sixth threshold value α6 present in Equation (29) to Equation (31) are real numbers equal to or greater than 1.
Meanwhile, the first determination condition to the third determination condition may be conditions other than the conditions represented by Equation (26) to Equation (28) below so long as the first determination condition to the third determination condition are conditions representing that directions indicated by two eigenvectors are parallel to each other or an angle between the two eigenvectors is equal to or less than a predetermined angle.
In addition, the fourth determination condition to the sixth determination condition may be conditions other than the conditions represented by Equation (29) to Equation (31) below so long as the fourth determination condition to the sixth determination condition are conditions representing that two eigenvectors are equal to each other or are regarded as being equal to each other or an index value representing a degree of approximation between the two eigenvectors is equal to or greater than a threshold value. For example, that an absolute value of a difference value between two eigenvectors is equal to or less than a predetermined threshold value may be set as a condition.
First, the similarity determination unit 156 calculates three eigenvalues λE, MAX, λE, MID, and λE, MIN and three eigenvectors uE, MAX, uE, MID, and uE, MIN of the matrix E and three eigenvalues λS, MAX, λS, MID, and λS, MIN and three eigenvectors uS, MAX, uS, MID, and uS, MIN of the matrix S. And the similarity determination unit 156 determines whether or not the calculated eigenvalues and eigenvectors satisfy all of the first to sixth determination conditions represented by Equation (26) to Equation (31).
In a case in which the determination result is positive, the matrix E and the matrix S can be regarded as coinciding with each other. In this case, the distribution shape of a plurality of points on the sensor coordinate system ΣS indicated by the estimated geomagnetic vectors rE1 to rEN and the distribution shape of a plurality of points on the sensor coordinate system ΣS indicated by the magnetic vectors m1 to mN can be regarded as coinciding with each other and the distribution shape of a plurality of points on the sensor coordinate system ΣS indicated by the magnetic vectors m1 to MN can be regarded as a spherical surface. Consequently, the estimation value cE of the offset cOFF calculated by the offset calculation unit 140 can be regarded as correctly representing the offset cOFF.
On the other hand, in a case in which the determination result is negative, the distribution shape of a plurality of points on the sensor coordinate system ΣS indicated by the magnetic vectors m1 to mN is a distorted shape different from a spherical surface. Consequently, there is a high possibility that the estimation value cE of the offset cOFF calculated by the offset calculation unit 140 may not correctly represent the offset cOFF.
In this way, it is possible for the similarity determination unit 156 to determine whether or not the estimation value cE of the offset cOFF calculated by the offset calculation unit 140 based on the magnetic vectors m1 to mN stored in the memory unit 300 correctly represents the offset cOFF by determining whether or not the matrix E and the matrix S satisfy the first determination condition to the sixth determination condition.
Although, in this embodiment, the similarity determination unit 156 determines whether or not the matrix E and the matrix S satisfy all of the first to sixth determination conditions represented by Equation (26) to Equation (31), the present invention is not limited thereto. The similarity determination unit 156 may determine whether or not the matrix E and the matrix S satisfy at least some of the first to sixth determination conditions.
Even in a case in which the matrix E and the matrix S satisfy at least some of the first to sixth determination conditions, the matrix E and the matrix S can be regarded as coinciding with each other. Consequently, it is possible for the similarity determination unit 156 to determine whether or not the estimation value cE of the offset cOFF calculated by the offset calculation unit 140 correctly represents the offset cOFF.
Meanwhile, hereinafter, determination as to whether or not the matrix E and the matrix S can be regarded as coinciding with each other, i.e. determination as to whether or not the distribution shape of a plurality of points on the sensor coordinate system ΣS indicated by the estimated geomagnetic vectors rE1 to rEN and the distribution shape of a plurality of points on the sensor coordinate system ΣS indicated by the magnetic vectors m1 to mN can be regarded as coinciding with each other, will also be referred to as a first determination.
In addition, in the offset estimation apparatus as described above, a variable vector representing the geomagnetism in the rectangular coordinate system when the equipment is at the reference attitude may be defined as a reference variable vector, the reference variable vector minimizing the objective function may be defined as a reference estimated geomagnetic vector, and a vector obtained by changing the reference estimated geomagnetic vector by the attitude variation may be defined as an estimated geomagnetic vector, and the offset estimation apparatus may include a first determination unit for determining whether or not a degree of difference between a distribution shape of a predetermined number of points in the rectangular coordinate system indicated by a predetermined number of the estimated geomagnetic vectors respectively corresponding to a predetermined number of attitude variations calculated by the attitude calculation unit and a distribution shape of a predetermined number of points in the rectangular coordinate system indicated by a predetermined number of magnetic data output from the three-dimensional magnetic sensor is within a predetermined range and an offset adoption unit for adopting the estimation value of the offset as the offset in a case in which a determination result of the first determination unit is positive.
In addition, in the offset estimation apparatus as described above, a variable vector representing the geomagnetism in the rectangular coordinate system when the equipment is at the reference attitude may be defined as a reference variable vector, the reference variable vector minimizing the objective function may be defined as a reference estimated geomagnetic vector, and a vector obtained by changing the reference estimated geomagnetic vector by the attitude variation may be defined as an estimated geomagnetic vector, and the offset estimation apparatus may include a first determination unit for determining whether or not a degree of difference between a component of an estimated geomagnetic data distribution matrix representing distribution of a predetermined number of the estimated geomagnetic vectors respectively corresponding to a predetermined number of attitude variations calculated by the attitude calculation unit and a component of an magnetic data distribution matrix representing distribution of a predetermined number of magnetic data output from the three-dimensional magnetic sensor is within a predetermined range and an offset adoption unit for adopting the estimation value of the offset as the offset in a case in which a determination result of the first determination unit is positive.
In addition, in the offset estimation apparatus as described above, a variable vector representing the geomagnetism in the rectangular coordinate system when the equipment is at the reference attitude may be defined as a reference variable vector, the reference variable vector minimizing the objective function may be defined as a reference estimated geomagnetic vector, and a vector obtained by changing the reference estimated geomagnetic vector by the attitude variation may be defined as an estimated geomagnetic vector, and the offset estimation apparatus may include a first matrix calculation unit for calculating an estimated geomagnetic data distribution matrix representing distribution of a predetermined number of the estimated geomagnetic vectors respectively corresponding to a predetermined number of attitude variations calculated by the attitude calculation unit, a second matrix calculation unit for calculating an magnetic data distribution matrix representing distribution of a predetermined number of magnetic data output from the three-dimensional magnetic sensor, a similarity determination unit for determining whether or not eigenvalues and eigenvectors of the estimated geomagnetic data distribution matrix and eigenvalues and eigenvectors of the magnetic data distribution matrix satisfy some or all selected from among a first condition indicating that an eigenvector corresponding to a maximum eigenvalue of the estimated geomagnetic data distribution matrix and an eigenvector corresponding to a maximum eigenvalue of the magnetic data distribution matrix are parallel to each other or an angle between the two eigenvectors is equal to or less than a predetermined angle, a second condition indicating that an eigenvector corresponding to a middle eigenvalue of the estimated geomagnetic data distribution matrix and an eigenvector corresponding to a middle eigenvalue of the magnetic data distribution matrix are parallel to each other or an angle between the two eigenvectors is equal to or less than a predetermined angle, a third condition indicating that an eigenvector corresponding to a minimum eigenvalue of the estimated geomagnetic data distribution matrix and an eigenvector corresponding to a minimum eigenvalue of the magnetic data distribution matrix are parallel to each other or an angle between the two eigenvectors is equal to or less than a predetermined angle, a fourth condition indicating that an index value representing a degree of approximation between the maximum eigenvalue of the estimated geomagnetic data distribution matrix and the maximum eigenvalue of the magnetic data distribution matrix is equal to or greater than a predetermined value, a fifth condition indicating that an index value representing a degree of approximation between the middle eigenvalue of the estimated geomagnetic data distribution matrix and the middle eigenvalue of the magnetic data distribution matrix is equal to or greater than a predetermined value, and a sixth condition indicating that an index value representing a degree of approximation between the minimum eigenvalue of the estimated geomagnetic data distribution matrix and the minimum eigenvalue of the magnetic data distribution matrix is equal to or greater than a predetermined value, and an offset adoption unit for adopting the estimation value of the offset as the offset in a case in which a determination result of the similarity determination unit is positive.
Next, the accuracy determination process will be described.
As previously described, the accuracy determination process performed by the accuracy determination unit 130 is a process of determining whether or not, in a case in which the offset calculation unit 140 calculates an estimation value cE of the offset cOFF based on the attitude rotation matrices R1 to RN stored in the memory unit 300, accuracy of the calculation is high. In other words, the accuracy determination process is a process of determining whether or not the attitude rotation matrices R1 to RN stored in the memory unit 300 are data suitable for calculating the estimation value cE of the offset cOFF.
As previously described, the offset calculation unit 140 solves a simultaneous linear equation represented by Equation (18) to obtain an optimal solution XOPT and calculates an estimation value cE based on the optimal solution xOPT.
Generally, in a case in which, for calculation to obtain a solution of a simultaneous linear equation, a minimum eigenvalue of a coefficient matrix of the simultaneous linear equation is a small value, accuracy of the calculation is lower than in a case in which the minimum eigenvalue of the coefficient matrix of the simultaneous linear equation is a large value. Consequently, it is possible to evaluate accuracy of the calculation based on the minimum eigenvalue of the coefficient matrix of the simultaneous linear equation.
In the accuracy determination process according to this embodiment, a minimum eigenvalue λQ, MIN of a coefficient matrix of the simultaneous linear equation represented by Equation (18), i.e. a positive definite symmetric matrix Q, is defined as an accuracy index representing accuracy of calculation to obtain the solution of the simultaneous linear equation. The accuracy determination unit 130 determines whether or not accuracy of calculation represented by Equation (18) is equal to or greater than a predetermined accuracy based on the accuracy index, i.e. the minimum eigenvalue λQ, MIN.
Hereinafter, the accuracy determination process performed by the accuracy determination unit 130 will be described in detail.
As shown in
The index generation unit 132 generates a minimum eigenvalue λQ, MIN (i.e. accuracy index) of the matrix Q based on the attitude rotation matrices R1 to RN stored in the memory unit 300.
The condition determination unit 134 determines whether or not the eigenvalue λQ, MIN generated by the index generation unit 132 satisfies a condition represented by Equation (32) below to determine whether or not accuracy of calculation to obtain the solution of the simultaneous linear equation represented by Equation (18) is equal to or greater than a predetermined accuracy. Here, a threshold value β present in Equation (32) is a predetermined positive real number.
λQ,MIN≧β Equation (32)
In a case in which the determination result of the condition determination unit 134 is positive, i.e. the eigenvalue λQ, MIN satisfies the condition represented by Equation (32), accuracy of calculation to obtain the solution of the simultaneous linear equation represented by Equation (32) can be regarded as being equal to or greater than a predetermined accuracy. Consequently, the estimation value cE (optimal solution xOPT) calculated by Equation (18) can be regarded as a value correctly representing the offset cOFF. In this case, therefore, the offset calculation unit 140 calculates the estimation value cE of the offset cOFF based on the attitude rotation matrices R1 to RN stored in the memory unit 300.
On the other hand, in a case in which the determination result of the condition determination unit 134 is negative, there is a high possibility that the estimation value cE may not correctly represent the offset cOFF. In this case, therefore, the offset calculation unit 140 does not calculate the estimation value cE of the offset cOFF.
In this way, the accuracy determination unit 130 determines whether or not calculation of the estimation value cE of the offset cOFF performed by the offset calculation unit 140 based on the attitude rotation matrices R1 to RN stored in the memory unit 300 is proper by determining whether or not the eigenvalue λQ, MIN satisfies the condition represented by Equation (32).
As described above, the offset estimation apparatus may include an index generation unit for generating an accuracy index representing accuracy of calculation for the offset calculation unit to calculate the estimation value of the offset and a second determination unit for determining whether or not the accuracy index is equal to or greater than a predetermined threshold value, which is a positive real number, the objective function may be a function having, as a variable, a variable vector including each element of a reference variable vector, which is a variable representing the geomagnetism in the rectangular coordinate system when the attitude of the equipment is the reference attitude and each element of the offset variable vector as elements, the accuracy index may be a minimum eigenvalue of a coefficient matrix in a case in which the objective function is expressed in a quadratic form having each element of the variable vector as a variable, and the offset calculation unit may calculate the estimation value of the offset in a case in which a determination result of the second determination unit is positive and may not calculate the estimation value of the offset in a case in which the determination result of the second determination unit is negative.
The offset estimation apparatus according to the present invention can pre-evaluate accuracy of calculation performed by the offset calculation unit based on the accuracy index. In a case in which it is expected that accuracy of calculation performed by the offset calculation unit is low, therefore, it is possible to prevent the calculation from being performed. Consequently, it is possible for the offset estimation apparatus according to the present invention to prevent an incorrect estimate of the offset greatly deviating from a real offset from being calculated.
As described above, the offset estimation apparatus 100 according to this embodiment includes the offset calculation unit 140 for calculating the estimation value cE of the offset cOFF based on the attitude rotation matrices R1 to RN and the magnetic vectors m1 to mN stored in the memory unit 300.
The estimation value of the offset cOFF may also be calculated based only on the result of output from the three-dimensional magnetic sensor as disclosed, for example, in Japanese Patent Application Publication No. 2012-198112.
However, it is possible to calculate the estimation value of the offset cOFF more accurately or within a shorter time when the estimation value of the offset cOFF is calculated based on a combination of the results of output from a plurality of sensors for detecting different kinds of physical quantities than when the estimation value of the offset cOFF is calculated based on the result of output from one sensor for detecting one kind of physical quantity. In addition, it is possible to accurately calculate the estimation value of the offset cOFF even under a worse condition.
Here, such worse condition includes a case in which the change in attitude of the portable equipment 1 is small, for example, in a case in which all of the attitude A1 to AN are almost the same as the attitude A1 and each of the attitude rotation matrices R1 to RN and the unit matrix I3×3 are regarded as the same matrix or N rotation axes in N attitude changes represented by the attitude rotation matrices R1 to RN are regarded as the same axis.
The change in attitude of the portable equipment 1 can be expressed as distribution of a plurality of points on the sensor coordinate system ΣS indicated by the magnetic vectors m1 to mN. And the estimation value of the offset cOFF is calculated using a statistical method based on the distribution shape of the points. In a case in which the estimation value of the offset cOFF is calculated based only on the magnetic vectors m1 to mN, therefore, the magnetic vectors m1 to mN are not widely distributed in the sensor coordinate system ΣS under a bad condition that the change in attitude of the portable equipment 1 is small. As a result, the change in attitude of the portable equipment 1 is buried in noise of the magnetic vectors m1 to mN even in a case in which the distribution of the magnetic vectors m1 to mN is caused by the change in attitude of the portable equipment 1. For this reason, the change in attitude of the portable equipment 1 is not correctly reflected with respect to the calculated estimation value of the offset cOFF. That is, in this case, it is not possible to correctly obtain the estimation value of the offset cOFF.
In this embodiment, on the other hand, the estimation value cE of the offset cOFF is calculated based on the attitude rotation matrices R1 to RN generated using the angular velocity vectors ω1 to ωN represented by the angular velocity data W1 to WN output from the three-dimensional angular velocity sensor 60 in addition to the magnetic vectors m1 to mN represented by the magnetic data M1 to MN output from the three-dimensional magnetic sensor 50. Since the angular velocity vectors ω1 to ωN directly represent the change in attitude of the portable equipment 1, it is possible for the angular velocity vectors ω1 to ωN to correctly represent the change in attitude of the portable equipment 1 even in a case in which the change in attitude of the portable equipment 1 is small. Even under the poor condition that the change in attitude of the portable equipment 1 is small, therefore, it is possible to prevent the change in attitude of the portable equipment 1 from being regarded as noise and to use the change in attitude of the portable equipment 1 in calculating the estimation value cE of the offset cOFF. Consequently, it is possible for the offset estimation apparatus 100 according to this embodiment to calculate the estimation value cE of the offset cOFF, with respect to which the change in attitude of the portable equipment 1 is more correctly and sensitively reflected than in a case in which the estimation value of the offset cOFF is calculated based only on the magnetic vectors m1 to mN.
In this way, it is possible for the offset estimation apparatus 100 according to this embodiment to more accurately calculate the estimation value cE of the offset cOFF even under the worse condition than in a case in which the estimation value of the offset cOFF is calculated based only on the result of output from the three-dimensional magnetic sensor.
In addition, the offset estimation apparatus 100 according to this embodiment includes the distribution shape determination unit 150 for performing the process of determining whether or not the magnetic vectors mi to mN stored in the memory unit 300 are data suitable for calculating the estimation value cE of the offset cOFF, i.e. the distribution determination process.
In a case in which the magnetic vectors m1 to mN stored in the memory unit 300 are data not suitable for calculating the estimation value cE of the offset cOFF due to influence of noise, therefore, it is possible to determine that the estimation value cE of the offset cOFF calculated by the offset calculation unit 140 is a value not correctly representing the offset cOFF.
Meanwhile, determination as to whether or not the magnetic vectors m1 to mN stored in the memory unit 300 are data suitable for calculating the estimation value cE of the offset cOFF, i.e. determination as to whether or not the distribution shape of a plurality of points on the sensor coordinate system ΣS indicated by the magnetic vectors m1 to mN can be regarded as a spherical surface, may be performed based only on the result of output from the three-dimensional magnetic sensor as disclosed, for example, in Japanese Patent Application Publication No. 2012-198112.
However, it is possible to perform the determination more accurately or within a shorter time when the determination is performed based on a combination of the results of output from a plurality of sensors for detecting different kinds of physical quantities than when the determination is performed based on the result of output from one sensor for detecting one kind of physical quantity.
The distribution shape determination unit 150 according to this embodiment performs the distribution determination process based on the attitude rotation matrices R1 to RN set using the angular velocity vectors ω1 to ωN represented by the angular velocity data W1 to WN output from the three-dimensional angular velocity sensor 60 in addition to the magnetic vectors m1 to mN represented by the magnetic data M1 to MN output from the three-dimensional magnetic sensor 50. Consequently, it is possible for the offset estimation apparatus 100 according to this embodiment to perform the distribution determination process within a shorter time and more accurately than in a case in which the distribution determination process is performed based only on the result of output from the three-dimensional magnetic sensor.
In addition, the offset estimation apparatus 100 according to this embodiment includes the accuracy determination unit 130 for performing the process of determining whether or not, in a case in which the estimation value cE of the offset cOFF is calculated based on the attitude rotation matrices R1 to RN stored in the memory unit 300, accuracy of the calculation is high, i.e. the accuracy determination process.
In a case in which it is assumed that accuracy of the calculation to calculate the estimation value cE based on the attitude rotation matrices R1 to RN stored in the memory unit 300 is low, therefore, it is possible to prevent the offset calculation unit 140 from performing the offset calculation process, i.e. the process of calculating the estimation value cE. As a result, it is possible to prevent the estimation value cE not correctly representing the offset cOFF from being calculated.
In the first embodiment as described above, the distribution shape determination unit 150 performs the distribution determination process using the reference estimated geomagnetic vector rE1 calculated by the offset calculation unit 140.
A second embodiment is different from the first embodiment in that the distribution determination process is performed based only on the attitude rotation matrices R1 to RN and the magnetic vectors m1 to mN stored in the memory unit 300 without using the output value from the offset calculation unit.
Meanwhile, elements of each embodiment, which will hereinafter be illustrated, identical in operation and function to those of the first embodiment will be denoted by the symbols used in the above description and a detailed description thereof will be omitted (The same is equally applied to embodiments and modifications which will hereinafter be described).
The offset estimation apparatus 100A is identical in configuration to the offset estimation apparatus 100 according to the first embodiment except that the offset estimation apparatus 100A includes a distribution shape determination unit 120 instead of the distribution shape determination unit 150 and an offset calculation unit 140A instead of the offset calculation unit 140 and does not include the adoption unit 160.
In a case in which the result of the determination performed by the distribution shape determination unit 120 is positive and the result of the determination performed by the accuracy determination unit 130 is positive, the offset calculation unit 140 calculates an estimation value cE of the offset cOFF. Meanwhile, an offset calculation process performed by the offset calculation unit 140A is identical to the offset calculation process performed by the offset calculation unit 140 according to the first embodiment.
The distribution shape determination unit 120 performs a distribution determination process based on the attitude rotation matrices R1 to RN and the magnetic vectors m1 to mN stored in the memory unit 300.
As shown in
The first vector calculation unit 122 calculates a normalized eigenvector uS, MIN corresponding to the minimum eigenvalue λS MIN of the matrix S represented by Equation (20) based on the magnetic vectors m1 to mN stored in the memory unit 300.
The second vector calculation unit 124 calculates a normalized eigenvector uD, MAX corresponding to a maximum eigenvalue λD, MAX of a matrix D represented by Equation (33) below based on the attitude rotation matrices R1 to RN stored in the memory unit 300. Meanwhile, the second vector calculation unit 124 may calculate the eigenvector uD, MAX by calculating the matrix D using the matrix RAVE calculated by the offset calculation unit 140.
D=R
AVE
T
R
AVE Equation (33)
The condition determination unit 126 determines whether or not the eigenvector uS, MIN calculated by the first vector calculation unit 122 and the eigenvector uD, MAX calculated by the second vector calculation unit 124 can be regarded as being parallel to each other.
Specifically, the condition determination unit 126 determines whether or not the eigenvector uS, MIN and the eigenvector uD, MAX can be regarded as being parallel to each other by determining whether or not the eigenvector uS, MIN and the eigenvector uD, MAX satisfy a condition represented by Equation (34) below. Here, a value γ present in Equation (34) is a predetermined real number satisfying 0<γ<1.
In a case in which the result of the determination performed by the condition determination unit 126 is positive, i.e. in a case in which the eigenvector uS, MIN and the eigenvector uD, MAX are regarded as being parallel to each other, the estimation value cE calculated based on the magnetic vectors m1 to mN stored in the memory unit 300 can be regarded as correctly representing the offset cOFF. On the other hand, in a case in which the result of the determination performed by the condition determination unit 126 is negative, there is a high possibility that the estimation value cE calculated based on the magnetic vectors m1 to mN stored in the memory unit 300 may not correctly represent the offset cOFF.
In this way, the distribution shape determination unit 120 determines whether or not calculation of the estimation value cE of the offset cOFF performed by the offset calculation unit 140 based on the magnetic vectors m1 to mN stored in the memory unit 300 is proper by determining whether or not the eigenvector uS, MIN and the eigenvector uD, MAX satisfy the condition represented by Equation (34).
|uD,MAX·uS,MIN|≧γ Equation (34)
The present invention is not limited to the above embodiments but may be modified as follows. In addition, two or more of the following modifications may be properly combined within the scope of non-contradiction.
Although, in the first embodiment as described above, the distribution shape determination unit 150 performs the distribution determination process by performing the first determination, the distribution determination process is not restricted so long as the distribution shape determination unit 150 can determine whether or not the distribution shape of a plurality of points on the sensor coordinate system ΣS indicated by the magnetic vectors m1 to mN can be regarded as a spherical surface.
For example, the distribution determination process may be performed using a method disclosed in Japanese Patent Application Publication No. 2012-198112.
Although, in the embodiments and the modification as described above, the offset estimation apparatus 100 includes the attitude calculation unit 110, the accuracy determination unit 130, the offset calculation unit 140, the distribution shape determination unit 150, and the adoption unit 160, the offset estimation apparatus 100 may at least include the attitude calculation unit 110 and the offset calculation unit 140.
Although, in the embodiments and the modifications as described above, the offset estimation program 200 is stored in the ROM 30, the offset estimation program 200 may be recorded in a recording medium readable by the portable equipment 1 or a memory device included in a server device that is capable of communicating with the portable equipment 1.
In addition, the present invention provides a program of an offset estimation apparatus provided at equipment including a three-dimensional angular velocity sensor for periodically detecting angular velocities in three directions and for sequentially outputting detection results as angular velocity data and a three-dimensional magnetic sensor for periodically detecting magnetic components in three directions including geomagnetism and for sequentially outputting detection results as magnetic data, which are vector data in a three-axis rectangular coordinate system, to estimate an estimation value of an offset of the three-dimensional magnetic sensor using a computer, wherein the computer is functioned as an attitude calculation unit for periodically calculating an attitude variation of the equipment from a reference attitude based on the angular velocity data, a variable vector representing the geomagnetism in the rectangular coordinate system when the attitude of the equipment is changed from the reference attitude by the attitude variation being defined as a first variable vector, a variable vector obtained by subtracting an offset variable vector, which is a variable vector representing the estimation value of the offset, from the magnetic data being defined as a second variable vector, and an offset calculation unit for calculating the offset variable vector minimizing an objective function representing an error between a predetermined number of the first variable vectors corresponding to a predetermined number of attitude variations generated by the attitude calculation unit and a predetermined number of the second variable vectors corresponding to a predetermined number of magnetic data output from the three-dimensional magnetic sensor as the estimation value of the offset.
Number | Date | Country | Kind |
---|---|---|---|
2013-017747 | Jan 2013 | JP | national |