AlexSm 6d3e410c45 Remove CMakeLists from main (#2032) 7 months ago
..
ut bf0f13dd39 add ymake export to ydb 1 year ago
README.md 1eb755fbca Restoring authorship annotation for Vasily Gerasimov <UgnineSirdis@gmail.com>. Commit 2 of 2. 2 years ago
sliding_window.cpp 8af5b431af Restoring authorship annotation for <ygpr@yandex-team.ru>. Commit 2 of 2. 2 years ago
sliding_window.h 8af5b431af Restoring authorship annotation for <ygpr@yandex-team.ru>. Commit 2 of 2. 2 years ago
sliding_window_ut.cpp 8af5b431af Restoring authorship annotation for <ygpr@yandex-team.ru>. Commit 2 of 2. 2 years ago
ya.make bf0f13dd39 add ymake export to ydb 1 year ago

README.md

TSlidingWindow - скользящее окно

TSlidingWindow - класс скользящего окна, позволяющий поддерживать и обновлять определённое значение (максимум, сумму) в промежутке времени определённой длины. Разбивает общий временной промежуток на маленькие бакеты (число задаётся в конструкторе) и ротирует их, поддерживая значение за окно. Есть возможность также указать мьютекс или спинлок для синхронизации (по умолчанию TFakeMutex). Использование:

// Создаём окно, вычисляющее максимум за последние пять минут, поддерживая 50 бакетов со значениями.
TSlidingWindow<TMaxOperation<int>> window(TDuration::Minutes(5), 50);

// Загружаем значения в различные моменты времени
window.Update(42, TInstant::Now());

... // делаем какую-то работу
int currentMaximum = window.Update(50, TInstant::Now());

... // делаем ещё что-то
int currentMaximum = window.Update(25, TInstant::Now());

...
// Просто получаем значение максимума за последние 5 минут
int currentMaximum = window.Update(TInstant::Now());

...
int currentMaximum = window.GetValue(); // получение значения без обновления времени

Поддерживаемые функции

  • TMaxOperation - максимум
  • TMinOperation - минимум
  • TSumOperation - сумма