Участник:Vlad SG — различия между версиями
Vlad SG (обсуждение | вклад) |
Vlad SG (обсуждение | вклад) |
||
Строка 66: | Строка 66: | ||
<tex> | <tex> | ||
\begin{align} | \begin{align} | ||
− | + | T_\text{rnd} &\leqslant \sum\limits_{i}\left(m_i + \sum\limits_{j}E(\text{кэш промах на}\; j)\right) = \\ | |
&= \sum\limits_{i}\left(m_i + \sum\limits_{j=1}^{k-m_i}\frac{m_i}{k-j+1}\right) = \sum\limits_{i}m_i\left(1 + \sum\limits_{j=1}^{k-m_i}\frac{1}{k-j+1}\right) = \\ | &= \sum\limits_{i}\left(m_i + \sum\limits_{j=1}^{k-m_i}\frac{m_i}{k-j+1}\right) = \sum\limits_{i}m_i\left(1 + \sum\limits_{j=1}^{k-m_i}\frac{1}{k-j+1}\right) = \\ | ||
&= \sum\limits_{i}m_i\left(1 + \sum\limits_{j=m_i+1}^{k}\frac{1}{j}\right) = \sum\limits_{i}m_i(1 + H_k - H_{m_i+1}) \leqslant \sum\limits_{i}m_iH_k = H_k\sum\limits_{i}m_i | &= \sum\limits_{i}m_i\left(1 + \sum\limits_{j=m_i+1}^{k}\frac{1}{j}\right) = \sum\limits_{i}m_i(1 + H_k - H_{m_i+1}) \leqslant \sum\limits_{i}m_iH_k = H_k\sum\limits_{i}m_i | ||
Строка 76: | Строка 76: | ||
<tex> | <tex> | ||
\begin{align} | \begin{align} | ||
− | + | T_\text{opt} &= \sum\limits_{i=1}^{p}E(\text{кэш промах на}\; i) = \\ | |
&= \frac{1}{2}\left(\sum\limits_{i=1}^{p-1}\left(E(\text{кэш промах на}\; i) + E(\text{кэш промах на}\; i+1)\right) + E(\text{кэш промах на}\; 1) + E(\text{кэш промах на}\; p)\right) \geqslant \\ | &= \frac{1}{2}\left(\sum\limits_{i=1}^{p-1}\left(E(\text{кэш промах на}\; i) + E(\text{кэш промах на}\; i+1)\right) + E(\text{кэш промах на}\; 1) + E(\text{кэш промах на}\; p)\right) \geqslant \\ | ||
&\geqslant \frac{1}{2}\sum\limits_{i=1}^{p}m_i | &\geqslant \frac{1}{2}\sum\limits_{i=1}^{p}m_i | ||
\end{align} | \end{align} | ||
</tex> | </tex> | ||
+ | |||
+ | Из полученных оценок не сложно вывести: | ||
+ | |||
+ | <tex>T_\text{rnd} \leqslant 2H_k \cdot T_\text{opt}</tex> | ||
+ | |||
+ | Алгоритм является <tex>2H_k</tex>-оптимальным, или, что более практично, <tex>\mathcal{O}(\ln(k))</tex>-оптимальным. | ||
+ | |||
== Источники == | == Источники == |
Версия 11:41, 27 января 2022
Содержание
Формулировка
Пусть задана последовательность из
запросов к внешней памяти. Необходимо решить для каждого запроса: сохранить его значение в кэш размера или оставить его во внешней памяти.Основные определения
Определение: |
Кэш попадание (англ. cache hit) — результат обрабатываемого запроса уже хранится в кэше и его можно вернуть мгновенно. |
Определение: |
Кэш промах (англ. cache miss) — результат обрабатываемого запроса отсутствует в кэше и чтобы его получить необходимо обращаться к внешней памяти. При получении ответа мы так же можем сохранить новое значение в кэш, вытеснив(удалив) некоторое старое. |
Определение: |
Временем работы алгоритма кэширования будем называть количество кэш промахов случившихся при обработке всех запросов. |
При анализе случайных алгоритмов будем использовать матожидание количества кэш промахов при всех возможных случайных выборах, но для фиксированной последовательности запросов.
Определение: |
Онлайн алгоритм (англ. on-line algorithm) — алгоритм, который при обработке запроса не знает следующих запросов. |
Определение: |
Оффлайн алгоритм (англ. off-line algorithm) — алгоритм, которому на вход даются все запросы сразу. |
Определение: |
-оптимальность — свойство онлайн алгоритма, означающее что время работы этого алгоритма на любых входных данных не более чем в раз больше, чем у любого оффлайнового, с точностью до аддитивной константы. |
Проблема детерминированных алгоритмов
Теорема (О нижней оценке): |
Любой -оптимальный онлайн детерминированный алгоритм кэширования имеет . |
Доказательство: |
Обозначим и как время работы оптимального и детерминированного алгоритма на входе . По определению -оптимальности имеем . Покажем, что достаточно построить для любого такую последовательность запросов , что . Так как , получаем . С другой стороны можно квантор раскрыть для значения : , а потом снова перейти к пределу . Перепишем неравенства в следующем виде , откуда очевидно, что .Теперь построим . В последовательности будем использовать только различных запросов. Первыми запросами возьмём любые различные, а дальше, каждым следующим запросом поставим тот, результата которого нет в данный момент в кэше детерминированного алгоритма. Это хоть и не явное, но корректное задание последовательности, потому что имея алгоритм, мы можем вычислить каждый запрос в на основе предыдущих. Очевидно, что .Посмотрим как на будет работать следующий, возможно оптимальный оффлайн алгоритм (индекс mopt). Первые k элементов алгоритм добавит в кэш, так как они все различные. Когда случается промах, алгоритм среди значений в кэше и только что обработанного результата вытесняет то, которое в последующих запросах встречается первый раз как можно позже или не встречается совсем. При таком выборе, следующий кэш промах случится не менее чем через запросов. Предположим, что это не так, и кэш промах случился через запросов. Так как количество различных запросов на 1 больше размера кэша, то этот промах произошёл на запросе, который мы вытеснили из кэша в предыдущий раз. Из следует, что есть запросы, которые мы не встретили среди первых , а значит их первое вхождение будет после того значения, которое мы вытеснили. Получили противоречие, а значит предположение не верно. Оценим время работы возможно оптимального оффлайн алгоритма . Последнее неравенство выполнено, т.к. . Очевидно , откудаТеорема доказана. |
Вероятностный алгоритм (англ. random marking algorithm)
В данном алгоритме, у каждого элемента, хранящегося в кэше, может быть метка. Изначально меток ни на одном элементе нет.
Когда в кэш поступает запрос:
- Если кэш попадание, то просто помечаем значение.
- Если кэш промах
- Если все элементы уже помечены, снимаем пометки со всех значений.
- Берём случайное не помеченное значение и вытесняeм его, а новое значение помечаем.
Оценка времени работы алгоритма
Будем рассматривать только те запросы, которые ставят метку в кэше. Из алгоритма понятно, что если запрос не ставит метку, то кэш работает с уже помеченным значением, а значит это кэш попадание. Разобьём эти запросы на фазы так, чтобы границей между фазами был запрос, который сбрасывает все пометки. Так, первый запрос в первой фазе — это первый запрос во всей последовательности, а первый запрос в других фазах — это запрос, выполняющий сброс всех пометок. Пронумеруем фазы от
до . Рассмотрим фазу . Разделим все значения на 2 множества: старые — которые были в фазу и новые — все остальные. Обозначим количество новых значений в фазе как . Тогда количество старых будет .Посчитаем матожидание количества промахов на фазе
. Оно максимально, когда в фазе сначала идут новые значения, а потом старые, потому что тогда каждое новое значение имеет шанс вытеснить старое, и при обращении к нему случится кэш промах. Так как на начало фазы в кэше хранятся только значения фазы , то понятно, что все новые запросы фазы приведут к кэш промаху. Рассмотрим -й среди старых запросов. Посмотрим на те значения фазы , которые к текущему моменту были вытеснены или помечены. старых значений пометили сами себя, потому что они были в предыдущей фазе, а пометить себя не могли, а поэтому вытеснили случайное подмножество из остальных . Возможно они вытеснили кого-то из первых старых значений, которые при обработке вытеснили кого-то другого. Главное, что распределение это не меняет. Вероятность того, что -й старый запрос приведёт к кэш промаху, равена тому, что он был вытеснен из кэша .В итоге, матожидание времени работы алгоритма не превосходит суммы матожиданий кэш промахов на каждой фазе, которое мы ограничили сверху суммой
и матожиданием промахов на старых значениях.
Теперь оценим снизу время работы оптимального алгоритма. Рассмотрим фазы
и . Среди запросов этих фаз всего различных значений, а потому оптимальный алгоритм обязан промахнуться хотябы раз.
Из полученных оценок не сложно вывести:
Алгоритм является
-оптимальным, или, что более практично, -оптимальным.