iOS Swift:计算与RSSI的距离

时间:2017-12-19 09:13:46

标签: ios swift ibeacon kalman-filter

iBeacon测距过程(可从CoreLocation获得)不能提供iPhone与iBeacon的平滑距离,而是提供过多的波动值。我也尝试使用加权平均值,但它没有给出预期的结果。我遇到了解释使用卡尔曼滤波器去除信号噪声的link。我还遇到了一个已实现过滤器的swift framework。我的问题是如何应用卡尔曼滤波器逻辑来获得与iBeacon的平滑距离?我目前正在使用下面的代码来计算距离,但我不知道如何在其上应用卡尔曼滤波器。

func calculateNewDistance(txCalibratedPower: Int, rssi: Int) -> Double{
        if rssi == 0{
            return -1
        }
        let ratio = Double(exactly:rssi)!/Double(txCalibratedPower)
        if ratio < 1.0{
            return pow(10.0, ratio)
        }else{
            let accuracy = 0.89976 * pow(ratio, 7.7095) + 0.111
            return accuracy
        }

    }

这里txCalibratedPower传递为-74

1 个答案:

答案 0 :(得分:0)

当测距时,每个回调到didRangeBeacons都包含一个[Beacon]对象数组,每个元素都有一个rssi参数beacon.rssi。

您需要创建字典或其他数据结构来存储每个信标的最新rssi读数。为方便起见,我经常根据信标标识符在字典中使用密钥:

var recentRssiDict: [String:[Double]] = [:]

...

// inside didRangeBeacons
let dictKey = "\(beacon.uuid) \(beacon.major) \(beacon.minor)"
var recentRssis = recentRssiDict[dictKey] && []
recentRssis.append(beacon.rssi)
recentRssiDict[dictKey] = recentRssis
// TODO: delete old elements depending on how many you want to track

然后,您可以在最近的RSSI中应用基于这些读数的卡尔曼滤波算法来获得filteredRssi。最后,将filteredRssi插入距离算法。请在此处查看我的回答:

Understanding ibeacon distancing