zoukankan      html  css  js  c++  java
  • MaLoc: a practical magnetic fingerprinting approach to indoor localization using smartphones

    https://www.indooratlas.com/



    However, tracking the location of a mobile user requires
    frequent Wi-Fi scanning which is quite power hungry.


    This approach is based on the hypothesis
    that in an indoor setting the magnetic field is highly nonuniform,
    and the magnetic field fluctuations arise from both
    natural and man-made sources (e.g., steel and concrete structures
    and electric systems).

    The abnormalities of the magnetic
    field can be used as fingerprints for indoor localization.
    While this approach shares a similar idea as Wi-Fi fingerprinting,
    it certainly has several advantages [2, 7, 13, 22]: 1) independent
    from the Wi-Fi infrastructure; 2) more reliable than
    Wi-Fi; 3) the change of magnetic field with location is quite
    significant, allowing for precise positioning; 4) more power
    efficient.
    【the phone’s three axes (X, Y and Z).】
    【particles  --   samples】
    Different from Wi-Fi fingerprints which combine the radio
    signal strength from multiple access points, a magnetic fingerprint
    is basically a 3-axis vector which consists of the magnetic
    field readings along the phone’s three axes (X, Y and Z).
    Studies [2, 7, 21] show that in a large indoor space the magnetic
    fingerprints may not be unique. As a result, large localization
    error may occur. Most of the existing work [4, 11,
    12] leverage on Particle Filter (i.e., Monte Carlo Localization
    or MCL) to solve this problem and improve accuracy. The
    basic principle is to use random samples (also referred to as
    particles, i.e., hypothesis for the user’s state such as position
    and heading direction) to represent the posterior distribution
    of the user’s state. Particle filter recursively re-samples a set
    of particles according to a series of magnetic fingerprints and
    their spatial correlations to converge to the poster distribution
    of true state. The spatial correlations can be obtained through
    user motion estimation. Therefore, the performance of particle
    filter depends on: 1) motion estimation; 2) fingerprint
    measurement and the magnetic fingerprinting model; and 3)
    resampling.
    【1) motion estimation; 2) fingerprint
    measurement and the magnetic fingerprinting model; and 3)
    resampling.】

    【Monte Carlo Localization】


    【phone orientation  VS user orientation】
    【the magnetometers on different smartphones have to be carefully calibrated】
     When the phone changes its orientation, we get
    different vectors. One may collect and store the magnetic
    readings of all directions at any location [4, 7], which incurs
    high training cost, or use coordinate transformation [12],
    which is error-prone. But both measurement models result
    in the work based on particle filter [4, 11, 12] typically require
    the smartphone to head the same way as the user. This
    is obviously not practical. Moreover, the magnetometers on
    different smartphones have to be carefully calibrated before
    use. Magnetometer calibration is difficult considering a large
    number of smartphones. Therefore, a better measureme

    【user heading VS phone heading】

    The
    basic principle is to use random samples (also referred to as
    particles, i.e., hypothesis for the user’s state such as position
    and heading direction) to represent the posterior distribution
    of the user’s state.

    【a fast failure detection mechanism   Kidnapped Robot Problem】
    Third, existing particle filter methods suffer from the wellknown
    “Kidnapped Robot Problem” [24], in which the robot
    may believe it knows where it is while it does not. This may
    turn into a serious problem when localizing smartphones, i.e.,
    it may take a long time for the particle filter to realize localization
    failure, where localization errors can be arbitrary in
    this period. Hence, a fast failure detection mechanism during
    runtime is highly desired.

    【novel】
    【extracting both the horizontal and vertical components of the magnetic vector --- independent from phone orientation】
    【a novel motion estimation method covering step
    counting, step length estimation and user heading change estimation,
    which is independent from phone orientation】
     
    It combines a
    novel magnetic fingerprinting model with the common magnetic
    density fingerprinting model. The novel magnetic fingerprint
    model is obtained by extracting both the horizontal
    and vertical components of the magnetic vector, which has
    the key features of being independent from phone orientation.
    We also explore the gradient of magnetic fingerprints to avoid
    calibrating different smartphone magnetometers. Secondly,
    we propose a novel motion estimation method covering step
    counting, step length estimation and user heading change estimation,
    which is independent from phone orientation. To
    minimize estimation errors and improve system robustness,
    we propose a dynamic step length estimation algorithm and
    a heuristic resampling algorithm. Specially, the heuristic resampling
    algorithm allows smartphone for other use such as
    answering a call while walking, whereas in traditional particle
    filter it may arise heading offset change and introduce
    large errors into heading change estimation, and hence result
    in localization failure. Thirdly, we propose a localization
    quality estimation method by utilizing the clustering degree
    of particles. Based on this method, we design a localization
    failure detection method to address global localization failure,
    and our experiments show it is able to detect 92.6% of
    localization failure. Finally, we develop an efficient crowdsourcing
    method to collect magnetic fingerprints, aiming to
    improve the existing time-consuming and labor-intensive collection
    process [13].

    【gradients VS variance 】
    This suggests
    that we can use the gradients of fingerprints instead of
    raw fingerprint values to avoid calibrating different magnetometers.


    【inertial -- reevaluate】
    The motion model updates
    each particle’s state by estimating user’s motion leveraged
    on the inertial sensors. The measurement model then reevaluates
    the particles’ weights.

    【the
    motion model, the measurement model and the resampling
    model】
    Essentially, the performance of a particle filter
    based method completely depends on how these three models
    construct.

    【Gaussian noise】
    , Gl~N(0, σl) and Gθ~N(0, σθ) are used to enlarge the
    diversity of particles.

    【step length】
    The step length is different from
    one user to another, and even one person’s step length may be
    changed. Inaccurate step length estimation will lead to large
    localization errors, resulting in localization failure, which has
    been shown in the experiment in Section 9. We propose a dynamic
    step length estimation algorithm to effectively solve
    these uncertainties.

    【resample】
    resample new particles
    from old ones according to the discrete probability distribution
    generated by their weights.

    the current particles are generated from the
    last round of localization.

    【Steps Counting --- counting the number of peaks or valleys may not work 】

    As
    shown in Fig. 5, the acceleration values are captured by a
    smartphone carried in different ways, e.g., in hand, in the shirt
    pocket, and in the front pant pocket. The result shows that
    counting the number of peaks or valleys may not work for
    all cases.


    【acceleration variance --   acceleration variance 】
    We set four thresholds, T u
    acc, T d
    acc and T u
    time, T d
    time, to filter
    false cases.

    the upper bound and lower
    bound of the acceleration variance between two adjacent peak
    and valley

    【Dynamic Step Length Estimation】
    Maybe国庆期间的中科院“步态识人”论文--有参考点
    A particle with a higher
    weight is more close to the true state. On the other hand,
    this particle’s step length is also closer to the true step length.

    Based on this theory, we design a dynamic
    step length estimation algorithm. Instead of just using
    lweighted as step length, we design a queue Q size of
    Qsize to cache the most recent lweight.

    【queue Cache】
    Considering
    when the user’s heading changes, his step length may
    have some changes, resulting in uncertain influence on the
    step length estimation. In our algorithm, we will not put this
    part into the queue.

    【compass --- gyroscope - angular velocity 】
    Since compass does not work well in indoor environments,
    gyroscope may be a better choice. The gyroscope on a
    smartphone measures the angular velocity around the phone’s
    x, y and z axis, respectively.

    【gravity sensor --- gravity direction】
    gravity sensor on smartphone to obtain
    the angle changes around the gravity direction

    【heuristic  --- randomly samples new particles when the total
    non-normalized weight decreases】
    We propose a heuristic algorithm
    to solve this problem, inspired by the random particle filter
    [24] which randomly samples new particles when the total
    non-normalized weight decreases. Our algorithm heuristically
    samples parts of new particles in the resampling phase instead
    of only sampling from the old particles (See Algorithm
    1).


    【magnetic measurement model】

    Because in the measurement
    phase, each particle obtains the reference fingerprint Bx,y,θ
    at a location from the database according to its position (x, y)
    and heading θ (not phone’s heading θp due to inaccurate compass
    readings). As θ represents user’s heading, if it is not the
    same as the phone’s heading θp, the magnetic field reading
    on smartphone cannot map with any particle’s observation
    Bx,y,θ as it should be mapped to Bx,y,θp . This may result
    in localization failure. Therefore, using this type of observation
    on smartphone is not practical.



    We can extract both the vertical and horizontal
    components of Bp and construct a new observation value
    (Bh, Bv) (named HV fingerprint).



    【gravity sensor reading】

    the
    gravity sensor reading is very precise when the user stands
    still. However, noise will be introduced when the user moves,
    resulting in decreasing in precision or even localization failure.



    【accelerate the convergence】
    In this work, we combine both the magnitude B and (Bh, Bv)
    using a hybrid measurement model. The HV fingerprint has
    the advantage of more uniqueness, and it makes the particle
    filter converge to the right location faster. However, it is not
    as stable as the magnetic magnitude fingerprint. Therefore,
    we use the HV fingerprint to accelerate the convergence of
    MaLoc when localization starts, and then we switch it to the
    magnetic magnitude fingerprint for “tracking”.

    【clustering degree】


     As shown in Fig. 8, the data collector requires walking
    along these lines to cover an area. On each line, we set the
    starting point, the heading direction and the path length. We
    then walk along this path with a slow and constant speed. In
    this process, the tool application will record data captured by
    the magnetic sensor on smartphone. A magnetic fingerprint
    collected will be stored as < Bh, Bv > and the magnitude
    can be computed from it. We simply assume the data collector
    walking at a constant speed. Each magnetic fingerprint
    can then be mapped with its location easily.

    Eventually, we obtain a
    magnetic fingerprint in every 0.1m×0.1m square.



    【https://www.indooratlas.com/】
     

  • 相关阅读:
    在Electron中最快速预加载脚本
    Babel是什么?
    node、npm、chrome、v8、sandbox是什么?
    我的博客即将入驻“云栖社区”,诚邀技术同仁一同入驻。
    NN[神经网络]中embedding的dense和sparse是什么意思?
    记一次失败的docker排障经历
    paddlepaddle关于使用dropout小案例
    paddlepaddle如何预加载embedding向量
    最近在部署推荐系统环境时,遇到一个很奇葩都问题
    fluid.io.load_inference_model 载入多个模型的时候会报错 -- [paddlepaddle]
  • 原文地址:https://www.cnblogs.com/rsapaper/p/7655116.html
Copyright © 2011-2022 走看看