Идеальное хеширование — различия между версиями
(Отмена правки 32172 участника 217.66.152.89 (обсуждение)) |
Kabanov (обсуждение | вклад) |
||
Строка 5: | Строка 5: | ||
== Постановка задачи == | == Постановка задачи == | ||
− | + | Хеширование используется из-за превосходной средней производительности. Возможна ситуация, когда можно получить превосходную производительность хеширования в наихудшем случае. Такой ситуацией является статическое множество ключей, т.е. после того как все ключи сохранены в таблице, и их множество никогда не изменяется. | |
== Основная идея == | == Основная идея == | ||
Будем использовать двухуровневую схему хеширования с универсальным хешированием на каждом уровне. | Будем использовать двухуровневую схему хеширования с универсальным хешированием на каждом уровне. | ||
=== Первый уровень === | === Первый уровень === | ||
− | Используется тот же принцип, что и в случае хеширования с цепочками: <tex>n</tex> ключей хешируются в <tex>m</tex> ячеек с использованием хеш-функции <tex>h</tex>, выбранной из [[Универсальное_семейство_хеш-функций | семейства универсальных хеш-функций]] | + | Используется тот же принцип, что и в случае хеширования с цепочками: <tex>n</tex> ключей хешируются в <tex>m</tex> ячеек с использованием хеш-функции <tex>h(k) = ((a\cdot k+b) \bmod p)</tex>, тщательно выбранной из [[Универсальное_семейство_хеш-функций | семейства универсальных хеш-функций]] <tex>H_{p,m}</tex>, где <tex>p</tex> - простое число, превышающее значение любого из ключей. |
− | |||
=== Второй уровень === | === Второй уровень === | ||
− | На данном уровне будем использовать вторичную хеш-таблицу <tex>S_j</tex> | + | На данном уровне вместо создания списка ключей будем использовать вторичную хеш-таблицу <tex>S_j</tex>, хранящей все ключи, хешированные функцией <tex>h</tex> в ячейку <tex>j</tex>, со своей функцией <tex>h_j(k)=((a_j\cdot k + b_j) \bmod p) \bmod m_j</tex>, выбранной из множества <tex>H_{p,m_j}</tex>. Путем точного выбора хеш-функции <tex>h_j</tex> мы можем гарантировать отсутствие коллизий на этом уровне. Для этого требуется, чтобы размер <tex>m_j</tex> хеш-таблицы <tex>S_j</tex> был равен квадрату числа <tex>n_j</tex> ключей, хешированных функцией <tex>h</tex> в ячейку <tex>j</tex>. |
− | + | Не смотря на квадратичную зависимость, ниже будет показано, что при корректном выборе хеш-функции первого уровня ожидаемое количество требуемой для хеш-таблицы памяти будет <tex>O(n)</tex>. | |
== Необходимые условия == | == Необходимые условия == | ||
Строка 22: | Строка 21: | ||
Для того, чтобы гарантировать отсутствие коллизий на втором уровне, требуется, чтобы размер <tex>m_j</tex> хеш-таблицы <tex>S_j</tex> был равен квадрату числа <tex>n_j</tex> ключей, хешированных функцией <tex>h</tex> в ячейку <tex>j</tex>. Благодаря такому подходу, так как ни в одной из вторичных таблиц нет ни одной коллизии, время поиска в худшем случае будет равно константе. | Для того, чтобы гарантировать отсутствие коллизий на втором уровне, требуется, чтобы размер <tex>m_j</tex> хеш-таблицы <tex>S_j</tex> был равен квадрату числа <tex>n_j</tex> ключей, хешированных функцией <tex>h</tex> в ячейку <tex>j</tex>. Благодаря такому подходу, так как ни в одной из вторичных таблиц нет ни одной коллизии, время поиска в худшем случае будет равно константе. | ||
− | + | Ключи, хешированные функцией <tex>h</tex> в ячейку <tex>j</tex>, затем повторно хешируются во вторичную хеш-таблицу <tex>S_j</tex> размером <tex>m_j</tex> с использованием хеш-функции <tex>h_j</tex> , выбранной из множества <tex>H_{p,m_j}</tex>. | |
== Теоретическое обоснование == | == Теоретическое обоснование == |
Версия 13:28, 13 июня 2013
Определение: |
Идеальная хеш-функция — хеш-функция, которая без коллизий отображает различные элементы из множества объектов на множество ключей за времени в худшем случае. |
Содержание
Постановка задачи
Хеширование используется из-за превосходной средней производительности. Возможна ситуация, когда можно получить превосходную производительность хеширования в наихудшем случае. Такой ситуацией является статическое множество ключей, т.е. после того как все ключи сохранены в таблице, и их множество никогда не изменяется.
Основная идея
Будем использовать двухуровневую схему хеширования с универсальным хешированием на каждом уровне.
Первый уровень
Используется тот же принцип, что и в случае хеширования с цепочками: семейства универсальных хеш-функций , где - простое число, превышающее значение любого из ключей.
ключей хешируются в ячеек с использованием хеш-функции , тщательно выбранной изВторой уровень
На данном уровне вместо создания списка ключей будем использовать вторичную хеш-таблицу
, хранящей все ключи, хешированные функцией в ячейку , со своей функцией , выбранной из множества . Путем точного выбора хеш-функции мы можем гарантировать отсутствие коллизий на этом уровне. Для этого требуется, чтобы размер хеш-таблицы был равен квадрату числа ключей, хешированных функцией в ячейку .Не смотря на квадратичную зависимость, ниже будет показано, что при корректном выборе хеш-функции первого уровня ожидаемое количество требуемой для хеш-таблицы памяти будет
.Необходимые условия
Для того, чтобы гарантировать отсутствие коллизий на втором уровне, требуется, чтобы размер
хеш-таблицы был равен квадрату числа ключей, хешированных функцией в ячейку . Благодаря такому подходу, так как ни в одной из вторичных таблиц нет ни одной коллизии, время поиска в худшем случае будет равно константе.Ключи, хешированные функцией
в ячейку , затем повторно хешируются во вторичную хеш-таблицу размером с использованием хеш-функции , выбранной из множества .Теоретическое обоснование
Теорема: |
Если универсального множества хеш-функций, то вероятность возникновения коллизий не превышает . ключей сохраняются в хеш-таблице размером c использованием хеш-функции , случайно выбранной из |
Доказательство: |
Всего имеется универсального семейства хеш-функций , то для каждой пары вероятность возникновения коллизии равна . Пусть — случайная величина, которая подсчитывает количество коллизий. Если , то математическое ожидание числа коллизий равно пар ключей, которые могут вызвать коллизию. Если хеш-функция выбрана случайным образом из |
Это является очень хорошим результатом, если хотя бы вспомнить на примере парадокса дней рождения о том, что вероятность коллизий растет крайне быстро по сравнению с размером хеш-таблицы.
Теорема: |
Если мы сохраняем ключей в хеш-таблице в хеш-таблице размеров c использованием хеш-функции , выбираемой случайным образом из универсального множества хеш-функций, то , где — количество ключей, хешированных в ячейку . |
Доказательство: |
Первый переход в равенстве мы совершили благодаря формуле математического ожидания, в частности - линейности. . Далее мы воспользовались свойствамиОчевидно, что - просто общее количество коллизий, поэтому по свойству универсального хеширования математическое ожидание значения этой суммы не превышает А так как , то , ч.т.д. |
Теперь выведем 2 следствия из этой теоремы.
Теорема: |
Если мы сохраняем универсального множества хеш-функций, и устанавливаем размер каждой вторичной хеш-таблицы равным , то математическое ожидание количества необходимой для вторичных хеш-таблиц в схеме идеального хеширования памяти не превышает . ключей в хеш-таблице размером с использованием хеш-функции , выбираемой случайным образом из |
Доказательство: |
Поскольку для , согласно предыдущей теореме: , ч.т.д. |
Теорема: |
Если мы сохраняем универсального множества хеш-функций, и устанавливаем размер каждой вторичной хеш-таблицы равным , то вероятность того, что общее количество необходимой для вторичных хеш-таблиц памяти не менее , меньше чем . ключей в хеш-таблице размером с использованием хеш-функции , выбираемой случайным образом из |
Доказательство: |
Применим неравенство Маркова Пусть Тогда и . , ч.т.д. |
См. также
Ссылки
- Т. Кормен. «Алгоритмы. Построение и анализ» второе издание, Глава 11.5, стр. 308
- Д.Э. Кнут. «Искусство программирования: Сортировка и поиск" Том 3, Глава 6.4, стр. 563
- Perfect hash function — Wikipedia
- Universal and Perfect Hashing
- Универсальное хэширование. Идеальное хэширование