将加速度计数据从设备坐标转换为现实世界坐标
如果这是一个非常基本的问题,我真的很抱歉,但我别无选择,只能问它:如何将加速度计数据从设备坐标转换为现实世界坐标?
我的意思是,假设加速度计给我一些像 (Ax,Ay,Az) -在设备坐标中-,我应该应用什么转换来将值转换为 (Ax',Ay',Az') -在现实世界的坐标-,所以我可以使用现实世界坐标中的加速度矢量来计算设备是否正在向北、向东、向西南等方向加速?
过去几天我一直在解决这个问题。起初我认为这应该不难,但搜索了几十页后我还没有想出任何实用的东西。
顺便说一句,这里是我迄今为止实现的一些代码:
private SensorEventListener mSensorEventListener = new SensorEventListener() {
public void onAccuracyChanged(Sensor sensor, int accuracy){
}
public void onSensorChanged(SensorEvent event) {
switch(event.sensor.getType()){
case Sensor.TYPE_ACCELEROMETER:
accelerometervalues = event.values.clone();
AX.setText(accelerometervalues[0]+"");
AY.setText(accelerometervalues[1]+"");
AZ.setText(accelerometervalues[2]+"");
break;
case Sensor.TYPE_ORIENTATION:
orientationvalues = event.values.clone();
azimuth.setText(orientationvalues[0]+"");
pitch.setText(orientationvalues[1]+"");
roll.setText(orientationvalues[2]+"");
break;
case Sensor.TYPE_MAGNETIC_FIELD:
geomagneticmatrix =event.values.clone();
TAX.setText(geomagneticmatrix[0]+"");
TAY.setText(geomagneticmatrix[1]+"");
TAZ.setText(geomagneticmatrix[2]+"");
break;
}
if (geomagneticmatrix != null && accelerometervalues != null) {
float[] R = new float[16];
float[] I = new float[16];
SensorManager.getRotationMatrix(R, I, accelerometervalues, geomagneticmatrix);
//What should I do here to transform the components of accelerometervalues into real world acceleration components??
}
}
};
我有:
accelerometervalues
中本机坐标中的加速度向量。
地磁矩阵中的磁场值向量。
方位角、俯仰角和横滚角以方向值
表示。
旋转矩阵R
。 倾角矩阵I
。
我认为所有必要的信息都在那里,方位角、俯仰角和横滚角应该描述设备坐标系相对于现实世界坐标系的位移。另外,我相信 R 甚至可以用作设备坐标内的真正的北向量。
在我看来,获得现实世界中的加速度值只是对这些数据进行数学变换。我就是想不通。
提前致谢。
编辑:
我尝试直接将 accelerometervalues
的分量与旋转矩阵 R
(trueaccel=accel*R) 相乘,但它不起作用。
trueacceleration[0]= accelerometervalues[0]*R[0]+accelerometervalues[1]*R[1]+accelerometervalues[2]*R[2];
trueacceleration[1]= accelerometervalues[0]*R[1]+accelerometervalues[1]*R[4]+accelerometervalues[2]*R[7];
trueacceleration[2]= accelerometervalues[0]*R[2]+accelerometervalues[1]*R[5]+accelerometervalues[2]*R[8];
我还尝试将加速度计值与倾角矩阵 I 相乘。还与 R 和 I 相乘 (trueaccel=accel*R*I),但这也不起作用。调用 remapcoordinates()
并以之前的任何形式相乘也不会发生这种情况。
有人知道我做错了什么吗?
I'm really sorry if this is a very basic question, but I have not choice but ask it: How do you translate the accelerometer data from the device coordinates to real world coordinates?
I mean, assuming that the accelerometer is giving me somenting like (Ax,Ay,Az) -in device's coordinates-, what transformations should I apply to transform the values into (Ax',Ay',Az') -in real world's coordinates-, so I can use the acceleration vector in real worlds coordinates to calculate if the device is accelerating north, east, south-west,etc?
I have been working around this issue during the past few days. At first I thought that it shound't be difficult, but after searching dozens of pages I haven't come up with anything functional.
By the way, here is some code with what I've implemented so far:
private SensorEventListener mSensorEventListener = new SensorEventListener() {
public void onAccuracyChanged(Sensor sensor, int accuracy){
}
public void onSensorChanged(SensorEvent event) {
switch(event.sensor.getType()){
case Sensor.TYPE_ACCELEROMETER:
accelerometervalues = event.values.clone();
AX.setText(accelerometervalues[0]+"");
AY.setText(accelerometervalues[1]+"");
AZ.setText(accelerometervalues[2]+"");
break;
case Sensor.TYPE_ORIENTATION:
orientationvalues = event.values.clone();
azimuth.setText(orientationvalues[0]+"");
pitch.setText(orientationvalues[1]+"");
roll.setText(orientationvalues[2]+"");
break;
case Sensor.TYPE_MAGNETIC_FIELD:
geomagneticmatrix =event.values.clone();
TAX.setText(geomagneticmatrix[0]+"");
TAY.setText(geomagneticmatrix[1]+"");
TAZ.setText(geomagneticmatrix[2]+"");
break;
}
if (geomagneticmatrix != null && accelerometervalues != null) {
float[] R = new float[16];
float[] I = new float[16];
SensorManager.getRotationMatrix(R, I, accelerometervalues, geomagneticmatrix);
//What should I do here to transform the components of accelerometervalues into real world acceleration components??
}
}
};
I have:
A vector of accelerations in native coordinates in accelerometervalues
.
A vector of magnetic field values in geomagneticmatrix
.
Azimuth, pitch and roll in orientationvalues
.
Rotation matrix R
.
Inclination matrix I
.
I think all the necessary information is there, azimuth, pitch and roll should describe the displacement of the device's coordinate system in relation with the real world coordinate system. Also, I believe that R
is/can even be used as a true north vector inside the devices coordinates.
It seems to me that obtaing the values of acceleration in real world is just a mathematical transformation away from those data. I just can't figure it out.
Thanks in advance.
Edited:
I have tried directly multipliying the components of accelerometervalues
with the rotation matrix R
(trueaccel=accel*R) but it didn't work.
trueacceleration[0]= accelerometervalues[0]*R[0]+accelerometervalues[1]*R[1]+accelerometervalues[2]*R[2];
trueacceleration[1]= accelerometervalues[0]*R[1]+accelerometervalues[1]*R[4]+accelerometervalues[2]*R[7];
trueacceleration[2]= accelerometervalues[0]*R[2]+accelerometervalues[1]*R[5]+accelerometervalues[2]*R[8];
I have also tried multipliying accelerometervalues
with the inclination matrix I. Also multipliying with both R and I (trueaccel=accel*R*I) and that didn't work either. Neither does calling to remapcoordinates()
and then multiply in any of the previous forms.
Does anybody have an idea about what am I doing wrong?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(5)
好吧,我自己已经用数学方法解决了这个问题,所以请耐心等待。
如果您想将加速度矢量
accelerationvalues
转换为以现实世界坐标表示的加速度矢量trueacceleration
,一旦您将方位角、俯仰角和横滚角存储在orientationvalues< 中/code> 向量,只需执行以下操作:
Oki, I have worked this out mathematically myself so please bear with me.
If you want to translate an acceleration vector
accelerationvalues
into an acceleration vectortrueacceleration
expressed in real world's coordinates, once you have azimuth,pitch and roll stored in aorientationvalues
vector, just do the following:试试这个,它对我有用
Try this, its working for me
您需要能够知道参考坐标系,该坐标系还可以为您提供设备在“真实”世界坐标中的方向。如果没有这些信息,就不可能将您的数据转化为任何有用的东西。
例如,您的设备是否具有一种“定向”传感器,可以帮助理解加速度计数据(例如陀螺仪和指南针?)
You need to be able to know the reference coordinate system that also gives you the orientation of your device within 'real' world coordinates. Without that information, it look impossible to transform your data into anything useful.
For example, does your device have a type of 'directional' sensor that would help make sense of the accelerometer data (gyro & compass for example?)
我正在处理同样的问题。您可以做的是,将 R[] 矩阵乘以您的加速度矢量,瞧。
PS:加速度计值必须是4场向量,只需在最后一个场加0即可。
I am dealing with the same problem. What you can do is, as you have the R[] matrix multiply your acceleration vector and voilá.
PS: accelerometervalues must be a 4 field vector, just add 0 to the last field.
这就是我用来将加速度计数据从本地(移动)参考系映射到地球参考系的方法,以摆脱方向依赖性。由于在地球坐标系中,Z 轴指向天空,因此必须显示值 ~=9.81m/sec^2。我无法理解的一个现象是,当我将手机放在转椅上的任何方向并以恒定速度旋转时,XEarth 和 YEarth 值显示出 90 度相移的旋转,并像正弦/余弦波一样振荡,我假设北和东轴。
This is what I used to map accelrometer data from local(Mobile) frame of reference to Earth frame of reference, to get rid of orientation in dependency. Since in earth frame Z-axis is pointing towards the sky and must show value ~=9.81m/sec^2. One phenomenon that I couldn't understand is when I put phone on the revolving chair any any orientation and rotate at constant speed then XEarth and YEarth values shows rotation with 90 degree phase shift and oscillates like a sin/cosine wave which i assume North and East axis.