基于Wi-Fi的室内定位在美团总部的实践和应用

上传人:鲁** 文档编号:558301435 上传时间:2023-06-04 格式:DOCX 页数:19 大小:468.63KB
返回 下载 相关 举报
基于Wi-Fi的室内定位在美团总部的实践和应用_第1页
第1页 / 共19页
基于Wi-Fi的室内定位在美团总部的实践和应用_第2页
第2页 / 共19页
基于Wi-Fi的室内定位在美团总部的实践和应用_第3页
第3页 / 共19页
基于Wi-Fi的室内定位在美团总部的实践和应用_第4页
第4页 / 共19页
基于Wi-Fi的室内定位在美团总部的实践和应用_第5页
第5页 / 共19页
点击查看更多>>
资源描述

《基于Wi-Fi的室内定位在美团总部的实践和应用》由会员分享,可在线阅读,更多相关《基于Wi-Fi的室内定位在美团总部的实践和应用(19页珍藏版)》请在金锄头文库上搜索。

1、基于Wi-Fi的室内定位在美团总部的实践和应用(含详细设计及参考代码)室内定位技术的商业化必将带来一波创新高潮,尤其是在O2O领域,各种基于此技术的应用将出现在我们的面前。我们可以想象一些比拟常见的应用场景,比方在大型商场里面借助室内导航快速找到目标商铺,商店根据用户的具体位置向用户推送更多关于商品的介绍等等,这些应用会极好的效劳于O2O,提高用户体验。目前室内定位技术有很多,如A-GPS、蓝牙、超声,红外、信标、射频、Wi-Fi、计算机视觉等,这些技术综合比拟,其中以基于Wi-Fi的室内定位技术最为突出,无论从硬件投入、软件投入、实施难度、可控性,还是定位效果方面考察,都是有优势的。本文描述

2、了作者在美团总部从零开始构建基于Wi-Fi的室内定位系统的过程,具有广泛的借鉴意义。基于Wi-Fi的室内定位原理 为提供Wi-Fi效劳,室内会部署有热点AP,每一个无线AP都有一个全球唯一的MAC地址,并且一般来说无线AP在一段时间内是不会改变的。 设备可以程序控制扫描并收集周围的AP信号,无论是否加密,是否已连接,甚至信号强度缺乏以显示在无线信号列表中,都可以获取到AP播送出来的MAC地址。 对应每个AP,这里有两个重要数据,AP的MAC地址和信号强度,MAC地址可以决定是哪个AP;信号强度理论上是和AP之间的距离有函数关系的,就是根据信号强度可以算出和AP的距离。 设备将这些数据发送到位置

3、效劳器,效劳器就可以用一个算法计算出设备的地理位置并返回到用户设备。 定位的精度取决于AP的个数,信号的稳定程度,以及算法的选择。美团总部Wi-Fi部署情况美团总部于2021年1月搬入了望京科技园3期,新的办公室地上共4层,建筑面积一万多平米,共部署有86台无线AP,覆盖很充分,没有死角,这为良好的定位效果打下了根底。无线AP使用的是,ArubA AP-135,这是一款优秀的商用无线路由器,2.4-GHz/5-GHz双频。根底数据测绘第一步,建立AP的根底数据库是关键,至少需要如下信息: AP的MAC地址,这里是双频的AP,就是有2个无线MAC地址 AP的物理位置关于AP的物理位置,这里因为范

4、围太小,加之无法找到足够精度的参考点,所以AP的物理位置无法使用GPS坐标,只能使用自定义坐标系。这里有2种选择: 以建筑的东南角为参考点坐标原点,这样就可以测绘AP相对原点的坐标,包含Z轴,单位是米 以测绘图的图片为参考,以AP在图中的像素位置为坐标,单位是1像素点这里选用了后一种方法,因为后一种方法容易测绘,大局部工作在电脑上操作即可;前一种方法需要更多的实地测绘工作。关于AP的MAC地址,从IT那里要到了一个列表,如下图:但是很不幸,这里的MAC地址是路由器的WAN口的MAC地址,而我们需要的是两个无线模块的MAC地址。这里只能自己测绘了,我写了一小段Android程序,可以排序出最近的

5、AP的MAC地址,然后挨个跑到各个AP下,运行程序,记下两个MAC地址;同时记录下AP的真实物理位置。WifiManager wm = (WifiManager) getSystemService(Context.WIFI_SERVICE);wm.startScan(); /开始扫描AP/等待一段时间,时间可长可短List results = wm.getScanResults(); /拿到扫描的结果Collections.sort(results,this); /this是个Comparator,按照level排序/去掉非sankuai的SSID/在UI线程中,显示到界面上int max=M

6、ath.min(30,results.size();for(int i=0;imax;i+) ScanResult one = results.get(i); text1.append(n+one.BSSID+tt+one.level);图中信号最强的就是当前AP的MAC地址,然后地址与它相近的是这个AP另一个频段的MAC地址,两个MAC地址都是0结尾,尾数相差1,容易识别。MAC地址后面的数字是信号强度,单位是dBm,是个负数。然后在底图中标注好AP的准确的物理位置,图中红色圆点即是AP位置,其圆心的像素坐标当作AP的坐标。测绘的数据应该存入数据库,这里设计了一个POJO,效劳器端程序可以使

7、用:public class MtApLoc private int id; /数字ID 人工定,有一定含义 private String id1; /字符串ID 从IT给表中来 private String mac1; /WAN MAC地址,有线口的 private String sn; /AP的 SN 从IT给表中来 private String sku; /资产编号 N 从IT给表中来 private String mac2; /无线MAC 1 ,测绘得来 private String mac3; /无线MAC 2 ,测绘得来 private int pn; /图号 对应楼层 priva

8、te float x; /物理坐标 x 自定义坐标系中 private float y; /物理坐标 y 自定义坐标系中然后将测绘的数据录入数据库,最后得到的数据如:其中的x,y是此AP在对应楼层的测绘图的图片中的坐标。MAC2和MAC3是AP的两个MAC地址这里没有区分2.4G和5G,和上面的测绘客户端的截图比拟,能看出当时我是站在AP7下的。把所有86个AP的物理位置和MAC地址测绘收集全后,测绘过程完成。Android客户端例如这里写了一个Demo用的android客户端,来测试定位结果,先看客户端运行截图:点击定位按钮,系统会扫描AP,然后把结果请求到效劳器。HttpPost post

9、 = new HttpPost(BaseUrl + /gar/locate/ap-locate.html);List parameters = new ArrayList();for (ScanResult result : results) parameters.add(new BasicNameValuePair(mac, result.BSSID.toUpperCase(); parameters.add(new BasicNameValuePair(rssi, String.valueOf(result.level);post.setEntity(new UrlEncodedFormE

10、ntity(parameters, UTF-8);String res;synchronized (hc) HttpResponse response = hc.execute(post); res = EntityUtils.toString(response.getEntity(), UTF-8).trim();Log.w(TAG, res);效劳器返回其所在位置,是一个JSON字符串accuracy:0.0,message:ok Least Squares,pn:1,status:0,x:237.97249473061038,y:1241.8270604002646然后客户端显示pn对应

11、的底图,然后在底图的x,y位置上显示定位到的标志,即图中跳动的红心。客户端大局部代码都是UI相关代码,这里不贴出了。定位算法常见的室内定位的算法主要分为两类:基于测距技术的定位算法和距离无关的算法。基于测距技术的算法一般是通过节点之间的距离或者角度来计算出未知节点的位置,实际运用中常见的有:基于接收信号强度指示算法RSSI、到达角度算法AOA、到达时间算法TOA等。距离无关的算法有:质心法、APIT算法、凸规划算法等。这些算法都是利用节点之间的邻近关系实现定位的。一般来说,基于测距技术的算法比无需测距的精度要高,这里适合采用。首先确定一个信号强度和距离之间的关系,这需要了解电波传播模型。在自由

12、空间环境中,不考虑阻挡和多径传播,设发射端与接收端的距离为d,那么接收端的接收功率Pr可表示为:其中Pt为发射功率;Gt和Gr分别为发射和接收天线增益;为电波波长;Pt和Pr的单位是瓦特;Gt和Gr无量纲。由上式可以看出,在自由空间中,接收功率与距离d2成反比。在实际环境中,由于存在多径、障碍物、绕射等随机因素,无线电传播损耗与上式相比还是有较大变化。此时,常采用对数-常态分布模型更为合理:其中Pr单位为dBm ,d0一般取1。在一般室内定位中,考虑到环境、本钱、定位精度要求等因素,所使用的RSSI测距信号衰减模型进一步简化为:d为定位节点与参考点之间的距离,单位m;A为定位节点与参考点之间的

13、距离d为1m时测得的RSSI值;n为信号衰减因子,范围一般为24。在美团的环境中,我们取A为-50,n为2.1。这样根据信号强度,就能估算设备和AP之间的距离。定位方法一般是根据几何模型建立方程,然后求解方程得到节点坐标。只有一个AP的情况:这里目标点坐标只能取AP的坐标,精度取半径。两个AP的情况:这里取AB的中间位置,精度取AB的长度。三个AP的情况:这里取三个圆的一个共同交点。不过实际没有这么简单,因为距离都有误差,两个AP时,可能是这种情况:三个AP可能是这种情况:甚至这种:这只是三个AP,有更多AP时怎么办?这里考虑一般的情况:考虑一般的情况,设有n个AP,AP1,AP2,.,APn

14、,坐标是xi,yi)。目标点到这n个AP的距离是di。设目标点的坐标是X,Y,那么可列一个方程组,有n个等式:大家都减第一个等式,就消去了二次项,得到另一个方程组,有n-1个等式:常数项换个名字,得到:等式除以X的系数ai,变量换个名字,得到:等式有n-1个,现在问题变成了:一组点ui,vi满足p+uq=v,求最适宜的系数p,q,这是典型的最小二乘法。Java里可以用Apache Commons Math3这个library来解决最小二乘法,文档见SimpleRegression。这里还有一个问题,AP的坐标xi,yi是像素坐标,那di相应的需要是像素距离,需要做一个比例尺变换。比例很容易算,相关代码:public double getPicLen(double rssi) double f=(-rssi-50)/22.0; return 41.785*Math.pow(10,f);效劳器端代码例如通过上面的描述,效劳器端代码就很容易写了,这里给出主要代码:private String macs; /输入mac地址private float rssis; /输入信号强度private int pn; /输出,楼层private double x,y,accuracy; /输出,定位到的坐标 和 精度List

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 商业/管理/HR > 商业计划书

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号