geometry - 如何通过三角测量确定点的位置

标签 geometry sensors wireless triangulation

我正在从事定位无线传感器网络项目。我正在使用三角测量方法来估计无线传感器的位置,其中我有两个传感器,其位置已知:

A(x1,Y1)

and B(X2,Y2)

and the point that I want to locate is c(x,y)

我有这些点之间的距离:

AB, AC & BC

如何使用三角测量来做到这一点?

最佳答案

放置

a := dist(B,C), b := dist(A,C).
A := (a1,a2), B := (b1,b2), C := (x,y).

我们有

(x - a1)^2 + (y - a2)^2 = b^2           eq (1)
(x - b1)^2 + (y - b2)^2 = a^2

因此:

x^2 -2(a1)x + (a1)^2 + y^2 -2(a2)y + (a2)^2 = b^2
x^2 -2(b1)x + (b1)^2 + y^2 -2(b2)y + (b2)^2 = a^2

现在减去:

(2(b1) - 2(a1))x + (a1)^2 - (b1)^2 + 2((b2) - (a2))y + (a2)^2 - (b2)^2
    = b^2 - a^2

求解y:

y = u + vx                              eq (2)

地点:

u := ((a1)^2 + (a2)^2 - ((b1)^2 + (b2)^2) + a^2 - b^2)/(2((a2) - (b2)))
v := (2((b1) - (a1)))/(2((a2) - (b2)))

将上面等式 1 中的 y 替换为 u + vx:

(x - a1)^2 + (u + vx - a2)^2 = b^2 

rx^2 + sx + t = 0

地点:

r := 1 + v^2
s := -2(a1) + 2uv - 2v(a2)
t := (a1)^2 + (uˆ2) - 2u(a2) + (a2)^2 - b^2

求解x

x = (-s +/- sqrt(s^2 - 4rt))/(2r)

从等式2:

y = u + vx.

替代方法

a := dist(B,C)b := dist(A,C) 如上,并放置 c := dist(A ,B)。theta为角度BAC,如下所示。

enter image description here

我们有

cos(theta) = (b^2 + c^2 - a^2)/(2bc)    eq (3)

然后我们可以导出hc1

h := b * sin(theta) = b * sqrt(1 - cost(theta)^2).
c1 := b * cos(theta)

所以,

D := (d1, d2) = (B - A) * c1 / c + A    eq (4)

哪里

d1 := (b1 - a1)*c1/c + a1
d2 := (b2 - a2)*c1/c + a2

现在我们可以利用以下事实:C 位于与 AB 相交于 D 的垂直线上,距离 h >:

C := (d1, d2) +/- ((a2 - b2)*h/c, (b1 - a1)*h/c) 

其中 +/- 代表 C 位于 AC 线上方或下方的两种可能性。

C = (x, y)

哪里

x := d1 +/- (a2 - b2)*h/c
y := d2 +/- (b1 - a1)*h/c

示例

A = (2,3) - B = (5,4) - a = sqrt(5) - b = sqrt(5)

计算c:

c := dist(A,B) = 3.16227766016838.

根据式(3)

cos(theta) = 0.70710678118655
theta := 0.78539816339745 radians

计算hc1:

h := b * sin(theta) = 1.58113883008419.
c1 := b * cos(theta) = 1.58113883008419.

根据等式(4):

D = (3.5,3.5)

现在计算C:

C = ((a2 - b2)) * h / c , (b1 - a1) * h / c) + D
  = (-0.5,1.5) + (3.5,3.5)
  = (3,5)

验证:

dist(A,C) = dist((2,3),(3,5)) = sqrt(1ˆ2 + 2^2) = b (OK)
dist(B,C) = dist((5,4),(3,5)) = sqrt(2^2 + 1^2) = a (OK)

关于geometry - 如何通过三角测量确定点的位置,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29810588/

相关文章:

javascript - THREE.js 动态添加点到 Points 几何不渲染

python - 将字节数组从\xff 转换为 x0FF

安卓方向传感器

linux - AR9485 无线网络适配器,带 linux mint

embedded - 蓝牙开发套件,允许定制调制算法

opengl - 我应该如何处理(变形)opengl中的4D对象?

javascript - 如何判断两个多边形相同?

安卓 View 和传感器

c# - 使用托管 API 关闭 WiFi 连接

c - 将线段延伸特定距离