留言板

尊敬的读者、作者、审稿人, 关于本刊的投稿、审稿、编辑和出版的任何问题, 您可以本页添加留言。我们将尽快给您答复。谢谢您的支持!

姓名
邮箱
手机号码
标题
留言内容
验证码

基于卡尔曼平滑的AWKNN室内定位方法

孙伟 段顺利 闫慧芳 丁伟

孙伟, 段顺利, 闫慧芳, 丁伟. 基于卡尔曼平滑的AWKNN室内定位方法[J]. 电子科技大学学报, 2018, 47(6): 829-833. doi: 10.3969/j.issn.1001-0548.2018.06.005
引用本文: 孙伟, 段顺利, 闫慧芳, 丁伟. 基于卡尔曼平滑的AWKNN室内定位方法[J]. 电子科技大学学报, 2018, 47(6): 829-833. doi: 10.3969/j.issn.1001-0548.2018.06.005
SUN Wei, DUAN Shun-li, YAN Hui-fang, DING Wei. AWKNN Indoor Location Methods Based on Kalman Smoothing[J]. Journal of University of Electronic Science and Technology of China, 2018, 47(6): 829-833. doi: 10.3969/j.issn.1001-0548.2018.06.005
Citation: SUN Wei, DUAN Shun-li, YAN Hui-fang, DING Wei. AWKNN Indoor Location Methods Based on Kalman Smoothing[J]. Journal of University of Electronic Science and Technology of China, 2018, 47(6): 829-833. doi: 10.3969/j.issn.1001-0548.2018.06.005

基于卡尔曼平滑的AWKNN室内定位方法

doi: 10.3969/j.issn.1001-0548.2018.06.005
基金项目: 

国家自然科学基金 41304032

辽宁省高等学校杰出青年学者成长计划 LJQ2015044

辽宁省自然科学基金 2015020078

辽宁省百千万人才工程培养项目 辽百千万立项【2014】76号

教育部国家级大学生创新训练项目 201710147000353

教育部国家级大学生创新训练项目 201710147000051

详细信息
    作者简介:

    孙伟(1984-), 男, 博士, 教授, 主要从事组合导航与室内定位方法方面的研究

  • 中图分类号: TN96

AWKNN Indoor Location Methods Based on Kalman Smoothing

图(7)
计量
  • 文章访问数:  4323
  • HTML全文浏览量:  1384
  • PDF下载量:  110
  • 被引次数: 0
出版历程
  • 收稿日期:  2017-08-17
  • 修回日期:  2018-09-16
  • 刊出日期:  2018-11-01

基于卡尔曼平滑的AWKNN室内定位方法

doi: 10.3969/j.issn.1001-0548.2018.06.005
    基金项目:

    国家自然科学基金 41304032

    辽宁省高等学校杰出青年学者成长计划 LJQ2015044

    辽宁省自然科学基金 2015020078

    辽宁省百千万人才工程培养项目 辽百千万立项【2014】76号

    教育部国家级大学生创新训练项目 201710147000353

    教育部国家级大学生创新训练项目 201710147000051

    作者简介:

    孙伟(1984-), 男, 博士, 教授, 主要从事组合导航与室内定位方法方面的研究

  • 中图分类号: TN96

摘要: 基于接收信号强度指示的WIFI室内定位方案存在采集信息跳变现象,进而影响定位精度的问题,提出一种基于卡尔曼滤波的改进自适应加权K最近邻(AWKNN)定位方法。对比分析多种平滑RSSI算法可行性,验证基于卡尔曼滤波对RSSI值进行平滑处理的优势,结合AWKNN算法并采用均方差计算匹配度,通过实时监控相匹配的无线接入点个数后自动调整均方差分母大小,以此实现定位误差的有效控制。实验结果表明,该基于卡尔曼的AWKNN算法在稳定性和定位精度方面较传统WIFI指纹算法有较大幅度提高。

English Abstract

孙伟, 段顺利, 闫慧芳, 丁伟. 基于卡尔曼平滑的AWKNN室内定位方法[J]. 电子科技大学学报, 2018, 47(6): 829-833. doi: 10.3969/j.issn.1001-0548.2018.06.005
引用本文: 孙伟, 段顺利, 闫慧芳, 丁伟. 基于卡尔曼平滑的AWKNN室内定位方法[J]. 电子科技大学学报, 2018, 47(6): 829-833. doi: 10.3969/j.issn.1001-0548.2018.06.005
SUN Wei, DUAN Shun-li, YAN Hui-fang, DING Wei. AWKNN Indoor Location Methods Based on Kalman Smoothing[J]. Journal of University of Electronic Science and Technology of China, 2018, 47(6): 829-833. doi: 10.3969/j.issn.1001-0548.2018.06.005
Citation: SUN Wei, DUAN Shun-li, YAN Hui-fang, DING Wei. AWKNN Indoor Location Methods Based on Kalman Smoothing[J]. Journal of University of Electronic Science and Technology of China, 2018, 47(6): 829-833. doi: 10.3969/j.issn.1001-0548.2018.06.005
  • 基于接收信号强度指示(RSSI)的室内定位方法,因具备性价比高、定位范围广且精度高的优势在众多领域存在应用价值[1-4]。但受室内障碍物遮挡、人员走动以及信号源功率不稳定影响,使用移动终端采集的RSSI信号中包含波动数据(“噪点”),导致基于指纹库的传统定位方法在移动终端位置估计中出现不准确现象[5-6]。由于现有指纹定位算法对于“噪点”处理较粗糙,而指纹库的好坏又对定位精度产生影响。如何剔除指纹库中信号“噪点”,通过优化指纹库来降低定位误差是室内定位技术中有待解决的关键问题。

    本文基于现有无线接入点(access point, AP)个数,提出一种基于卡尔曼平滑的改进自适应加权K最近邻(AWKNN)位置指纹定位算法。通过求取RSSI均方差代替欧氏距离,解决在一些错误匹配点上由于欧氏距离中的项数远小于匹配个数而导致欧氏距离变小,从而误判为最佳匹配点的问题。

    • 根据图 1所示的WIFI定位原理可看出,定位过程主要包括指纹数据库建立(离线阶段)和导航位置信息实时获取(在线阶段)两个阶段[7]。建立指纹数据库的主要工作是进行数据采集[8]。在待定位区域按照一定的距离间隔部署若干个参考点(reference point, RP),在每个参考点处采集接收到的来自所有AP的MAC地址、RSSI值以及对应的位置坐标等信息构建信号指纹库。为提高定位精度,可根据实际情况适当增加各RP处的采集时间,通过数据滤波方法将来自某一AP的RSSI值序列进行滤波处理,滤波结果作为该参考点上对应AP的RSSI值存入指纹数据库。

      图  1  基于WIFI的RSSI位置指纹定位原理

      在导航位置信息实时获取阶段,首先在测试点实时采集N组WIFI的RSSI值,通过比较测试点AP的RSSI与RP中记录的对应AP的RSSI,利用测试点AP的RSSI相似程度最大,即信号强度最接近的参考点估计位置作为目标定位结果[9-10]

    • 由于障碍物遮挡、人员走动、信号源功率不稳定以及多路径效应影响,导致移动终端采集的信号存在波动较大的数据,影响指纹库精确度[11-12]。围绕该问题,本文对比性分析均值滤波、高斯滤波和卡尔曼滤波对于改善RSSI精度的可行性。

    • 均值滤波是将参考点中各AP接收到的RSSI值分别求算术平均值:

      $$ \overline {{R_i}} = \frac{1}{n}\sum\limits_{k = 1}^n {{\text{RSS}}{{\text{I}}_{ik}}} $$ (1)

      式中,n为AP中RSSI样本数。均值滤波算法计算量小,无法对随机性误差进行有效处理。当RSSI样本数大、波动幅度低、突变次数少时,均值滤波对于信号的平滑度较高;当RSSI数值波动较大时,均值滤波对于误差的处理能力有限[13]

    • 高斯滤波是一种线性平滑滤波,通过假设数据的误差特性符合高斯分布,保留高斯分布密度较大区域的数值,过滤掉因干扰产生的小概率数值[14]

      假设移动终端接收到的RSSI值服从N${\text{(}}0,{\sigma ^2}{\text{)}}$的高斯分布,用变量x来表示RSSI,可得到:

      $$ F(x) = \frac{1}{{\sigma \sqrt {2\pi } }}{{\text{e}}^{\frac{{{{(x - \mu )}^2}}}{{2{\sigma ^2}}}}} $$ (2)

      式中,

      $$ \mu = \frac{1}{n}\sum\limits_{i = 1}^n {{x_i}} $$ (3)
      $$ \sigma = \sqrt {\frac{1}{{n - 1}}\sum\limits_{i = 1}^N {{{({x_i} - \mu )}^2}} } $$ (4)
      $$ P(\mu - \sigma \leqslant {x_i} \leqslant \mu + \sigma ) = 0.682\;6 $$ (5)

      如式(5)所示,当RSSI范围处于$[\mu - \sigma ,\mu + \sigma ]$之间时,保存滤波后结果,否则舍弃。

      根据高斯滤波降噪特性,可有效过滤跳变大且远离真值的数据,在一定程度上解决了RSSI数据稳定性较差的问题。但对于随机误差的影响以及样本数量较少时,其处理效果不理想。

    • 卡尔曼滤波是以最小均方误差为估计,利用观测值对当前预测值加以修正产生最佳估计值,不断递推得到优化后的结果[15]。通过不断优化后设置卡尔曼滤波观测误差$r = 4$、初始状态误差${p_0} = 10$,得到估计值${x_k}$的推导过程为:

      $$ {x_0}{\text{ = }}{y_1} $$ (6)
      $$ {x_{k,k - 1}} = {x_{k - 1}} $$ (7)
      $$ {p_{k,k - 1}} = {p_{k - 1}} $$ (8)
      $$ {k_k} = \frac{{{p_{k,k - 1}}}}{{{p_{k,k - 1}} + r}} $$ (9)
      $$ {x_k} = {x_{k,k - 1}} + {k_k}({y_k} - {y_{k,k - 1}}) $$ (10)
      $$ {p_k} = (1 - {k_k}){p_{k,k - 1}} $$ (11)

      式中,${y_1}$为第一个观测值;${x_{k,k - 1}}$为状态一步预测;${k_k}$为卡尔曼滤波增益;${p_k}$为状态估计误差。

      卡尔曼滤波以预测值、实测值、修正值的顺序递推,极大地跟随真值变动,是最贴近真值的适应动态环境的跟随算法。

    • 在同一个参考点上选取一个AP的120组RSSI值,分别对其进行均值滤波、高斯滤波和卡尔曼滤波,得到解算之后对比效果如图 2所示。

      图  2  滤波对比图

      通过对图 2分析可以看出,均值滤波信号平滑度相当高,当RSSI样本数大,波动幅度低时,可信度较高;但当样本数量少,数据突变多时,误差增大明显。高斯滤波保留RSSI分布密度大的数值,过滤掉偏离较大的数据,对于解决信号稳定性差这一问题做出了贡献,它对抑制服从正态分布的噪声效果很好。表面上高斯滤波结果与原始数据跟随性最好,但实际上对于对应区间内RSSI值高于粗差的波动,高斯滤波采用直接剔除法,没有对这些具有较大偏差数据进行更恰当的处理。当样本量较少、RSSI值波动严重时,高斯滤波处理可能会剔除大量原始数据,与实际所求相差甚远。卡尔曼滤波的核心思想是“预测+校正”,它可以对系统状态进行最优估计,跟随原始数据变化,以预测值、实测值、修正值的顺序递推,极大地跟随真值变动,是最贴近真值的适应动态环境的跟随算法。

      综上所述,卡尔曼滤波既能跟随原始数据变动,又可明显减缓波形抖动,减小误差,是对原始RSSI值进行滤波处理的最佳选择。本文将每个参考点中的每个AP的多个RSSI数据进行卡尔曼滤波后再求均值,最后将每个参考点中各个AP对应的数据存入指纹数据库中。

    • 在线定位阶段,主要进行移动用户的位置解算。传统WKNN是将测试点收到的RSSI与各个参考点的RSSI进行匹配。首先利用欧氏距离公式计算测试点与指纹库中各个参考点之间的欧氏距离,然后找出欧氏距离最小的K个参考点,最后将这K个参考点的位置坐标进行加权平均,估计出测试点的位置。由此得到测试点i接收来自n个AP的信号强度值为:

      $$ {\text{RSS}}{{\text{I}}_i} = ({\text{RSS}}{{\text{I}}_{i,1}},{\text{RSS}}{{\text{I}}_{i,2}}, \cdots ,{\text{RSS}}{{\text{I}}_{i,n}}) $$ (12)

      在现实环境中,由于信号遮挡、人员走动、其他设备干扰以及WIFI覆盖范围有限等因素,在定位区域较大的情况下,不同的位置点不可能接收到来自所有AP的无线信号。在一些错误匹配点上,测试点与参考点中相匹配的AP个数较其余测试点显著减少,这可能导致计算的欧氏距离较小,容易把这些错误匹配位置判断为最佳匹配点[16-17]

      为规避这种错误,提出一种以测试点与参考点RSSI值均方差为相似性度量的改进自适应WKNN定位算法。

      1) 选取测试点中1个AP与1个参考点中的各个AP进行匹配,当MAC地址相同时,匹配项数加1。2)选取该测试点中的其他AP依次与该参考点的各个AP进行匹配,当MAC地址相同时,匹配项数加1。3)对该测试点与该参考点接收到有相同的MAC地址的RSSI值计算均方差。4)该测试点依次与指纹库中所有的参考点遍历前3步。5)最后选取K个均方差最小的参考点,选其倒数为加权系数,对这K个参考点坐标进行加权处理,估计测试点坐标。6)对下一个测试点遍历前5步。

      均方差公式和估计的测试点坐标$(x,y)$分别为:

      $$ {d_{ij}} = \sqrt {\frac{{\sum\limits_{l = 1}^m {{{({\text{rss}}{{\text{i}}_{i,l}} - {\text{rss}}{{\text{i}}_{j,l}})}^2}} }}{m}} $$ (13)
      $$ ({x_i},{y_i}) = \frac{{\sum\limits_{j = 1}^K {\left( {\frac{1}{{{d_{ij}} + \varepsilon }}({x_j},{y_j})} \right)} }}{{\sum\limits_{j = 1}^K {\frac{1}{{{d_{ij}} + \varepsilon }}} }} $$ (14)

      式中,m为测试点i与参考点j匹配的AP个数;$\varepsilon $是为了防止分母为零而选取的一个随机接近于零的数。

    • 测试环境如图 3所示,以地板砖(尺寸:0.6 m×0.6 m)为基准进行划分选取参考点,共选取2×80个方格点作为参考点。

      图  3  测试环境

      实验所用AP均为学校统一布设,但路由器位置不相同,定位时均用该点可测得的所有AP。实验过程中,采集数据所用的软件为利用Java语言编写基于Android平台的数据采集APP,采集各个点的MAC地址、RSSI值、位置坐标等信息,如图 4所示。在离线阶段每个参考点采集20次,RSSI检测间隔为1 s。

      图  4  手机数据采集软件界面

      在线阶段在走廊上选取30个测试点,每个点上采集20次,基于信号强度跳变是一直存在的现象,在定位阶段仍需对数据进行卡尔曼平滑处理。图 5为基于AWKNN定位算法的测试分析图,图中以平面图所示方向建立坐标系,xy轴均为坐标值,‘○’为参考点的位置,它是以0.6 m×0.6 m为间隔,图中‘+’为测试点的真实位置,‘×’为测试点的解算位置。

      图  5  AWKNN定位结果

      为进一步验证本文AWKNN定位算法的有效性和可行性,采用相同的经过卡尔曼滤波的指纹数据库,分别进行WKNN和AWKNN两种算法的定位实验,得到这两种算法的误差比较及误差累计分布分别如图 6图 7所示。

      图  6  WKNN与AWKNN算法定位误差比较

      图  7  误差累积分布概率图

      图 6所示,AWKNN算法的收敛距离为3.8 m,优于WKNN算法的4.5 m收敛距离,AWKNN算法相较传统的WKNN算法而言,定位精度整体有所提升,整体平均误差由原来的2.93 m降低到2.36 m,定位误差在4 m内的比例由原来的70%提高到86.7%,定位在3 m内的比例由原来的60%提高到76.7%。

      根据图 7,从定位精度稳定性和收敛距离来分析,基于卡尔曼平滑的AWKNN算法优于WKNN算法,这在无线路由众多并要求精度达到可视距离的建筑内可满足使用要求。

    • 移动端采集的RSSI受外界因素影响存在跳变数据,导致定位误差大。本文对比性地分析均值滤波、高斯滤波和卡尔曼滤波对于优化RSSI值的可靠性,验证了卡尔曼滤波具有良好的跟随真值变动特性。提出的AWKNN算法,通过利用m个相匹配AP均方差代替欧氏距离进行解算。对比性实验测试表明,基于卡尔曼滤波的AWKNN定位算法得到的收敛距离优于WKNN算法得到的结果,定位误差得到有效控制。本文的定位方法可为今后开展室内WIFI定位方案的优化提供参考。

      本文的研究工作得到了辽宁工程技术大学研究生教育创新计划(YS201608)的资助,在此表示感谢!

参考文献 (17)

目录

    /

    返回文章
    返回