水平仪是一种我们用来测量静止物体水平面的工具或仪器,传统水平仪是透明管中填充液体并通过汽包的位置来判断是否水平,而电子水平仪不仅可以测量是否水平还能检测出当前倾斜角是多少,技术方案上通常使用加速度传感器来计算倾斜角。
1. 什么是倾斜角
倾斜角是指某物体相对于水平面的夹角,具体指物体参考轴与水平面的夹角(如下图所示),水平面以上为正,水平面以下为负,倾斜角的范围为【-π/2,π/2】,若超过此范围取其补角,简化模型如下所示:
2. 倾角计算原理
2.1. arcsin计算
如下图所示我们能够通过传感器测量Ax方向的加速度值,物体的倾斜角为θ,当加速度传感器静止时也就是侧面和垂直方向没有加速度作用,那么作用在它上面的只有重力加速度。根据三角关系重力加速度与物体垂直方向的夹角为倾斜角θ。简化模型如下:
测量轴重力方向的加速度存在关系:
通过反三角函数计算得到倾斜角θ:
通过上面表达式我们已能够测量出设备的倾斜角,但是重力加速度g不能获取到一个精确的值(一般情况重力加速度取9.8),导致存在测量误差误差,不仅如此重力加速度还会随高度的变化而变化(重力加速度是由于地心引力产生的,引力随距离变化而变化,加速度也随之变化),这让测量误差进一步不可控,为此在物体静止下,重力加速度g值可以通过一下方式得到:
联合上述公式可得到:
上面倾斜角θ表达式中误差已与准确的重力加速度值无关,由不准确的重力加速度和因高度不同引起不同重力加速度引入的误差得到控制。除了通过arcsin计算方法之外我们还可以通过arctan来计算倾斜角。
2.2. arctan计算
参考arcsin计算倾斜角,也可以通过arctan计算倾斜角,如下:
由于不同的海拔高度下g值不一样,g值可以通过一下方式得到:
联合上述公式可得到:
3. 工程应用
在实际的工程应用不会直接使用使用公式进行倾角计算,会在计算前使用一些数据处理手段让整个结果更加稳定和准确,常规的做法是对每个轴加速度值通过一个合适的中值滤波算法,然后再通过一个合适的均值滤波算法,最终将滤波处理后的数据再使用倾角计算公式进行倾角计算。
另外一个问题在工程中也较为容易遇到:加速度轴和物体外形的参考轴存在非零夹角,若我们直接使用倾角计算公式计算加速度计的倾斜角,然后再对加速度的倾角进行固定补偿,在一些情况下能够得到物体正常的倾角,但某些角度存在模糊问题不能被解决,这时我们需要对加速度计的相对与物体外形的每个轴重新进行矢量分解,采用矢量分解后的加速度计算倾斜角将能解决模糊问题,分解如下图所示:
转换公式如下: