• Felix Fietkau's avatar
    mac80211: minstrel_ht: replace rate stats ewma with a better moving average · b1103d25
    Felix Fietkau authored
    Rate success probability usually fluctuates a lot under normal conditions.
    With a simple EWMA, noise and fluctuation can be reduced by increasing the
    window length, but that comes at the cost of introducing lag on sudden
    changes.
    
    This change replaces the EWMA implementation with a moving average that's
    designed to significantly reduce lag while keeping a bigger window size
    by being better at filtering out noise.
    
    It is only slightly more expensive than the simple EWMA and still avoids
    divisions in its calculation.
    
    The algorithm is adapted from an implementation intended for a completely
    different field (stock market trading), where the tradeoff of lag vs
    noise filtering is equally important. It is based on the "smoothing filter"
    from http://www.stockspotter.com/files/PredictiveIndicators.pdf.
    
    I have adapted it to fixed-point math with some constants so that it uses
    only addition, bit shifts and multiplication
    
    To better make use of the filtering and bigger window size, the update
    interval time is cut in half.
    
    For testing, the algorithm can be reverted to the older one via debugfs
    Signed-off-by: default avatarFelix Fietkau <nbd@nbd.name>
    Link: https://lore.kernel.org/r/20191008171139.96476-2-nbd@nbd.nameSigned-off-by: default avatarJohannes Berg <johannes.berg@intel.com>
    b1103d25
rc80211_minstrel.c 17.4 KB