Что такое findslide.org?

FindSlide.org - это сайт презентаций, докладов, шаблонов в формате PowerPoint.


Для правообладателей

Обратная связь

Email: Нажмите что бы посмотреть 

Яндекс.Метрика

Презентация на тему Сжатие информации. Алгоритм Хаффмана

Содержание

Сжатие информацииСжатие данных – сокращение объема данных при сохранении закодированного в них содержания.
Сжатие информацииАлгоритм Хаффмана Сжатие информацииСжатие данных – сокращение объема данных при сохранении закодированного в них содержания. Сжатие информацииСжатие происходит за счет устранения избыточности кода, например, за счет упрощения Алгоритмы сжатия1. Равномерное сжатие с использованием кодов одной длины.Этот метод используется, если Сжатие с использованием кодов переменной длиныВ этом случае возникает проблема отделения кодов Префиксные кодыЧтобы понять, как строятся префиксные коды, рассмотрим, как построить ориентированный граф, Префиксные кодыПостроим граф этого кода.Из начальной вершины выходят две дуги, помеченные 0 Префиксные кодыЕсли при этом какое-то последовательность оказывается прочитанным полностью, то у конца Префиксные кодыЕсли известен граф, созданный по префиксному коду, то по этому графу Алгоритм ХаффманаАлгоритм Хаффмана — адаптивный алгоритм оптимального    префиксного кодирования алфавита с минимальной избыточностью. Был разработан 1952 году аспирантом Массачусетского 1. Символы исходного алфавита образуют вершины. Вес каждой вершины вес равен количеству НА_ДВОРЕ_ТРАВА,_НА_ТРАВЕ_ДРОВА Составим таблицу кодов символов: Найдем объем сообщения после кодирования кодом Хаффмана: 2·6 + 3·4 + 4·2 Математики доказали, что среди алгоритмов, кодирующих каждый символ по отдельности и целым Для кодирования сообщения, состоящего из букв А, Б, В, Г и Д, Задача А9. Решение.Построим двоичное дерево, в котором от каждого узла отходит две Задача А9. Решение.По дереву определим, что для букв Г и Д код Для передачи по каналу связи сообщения, состоящего только из букв А, Б, Для 5 букв латинского алфавита заданы их двоичные коды. Эти коды представлены Для передачи по каналу связи сообщения, состоящего только из букв А, Б,
Слайды презентации

Слайд 2 Сжатие информации
Сжатие данных – сокращение объема данных при

Сжатие информацииСжатие данных – сокращение объема данных при сохранении закодированного в них содержания.

сохранении закодированного в них содержания.


Слайд 3 Сжатие информации
Сжатие происходит за счет устранения избыточности кода,

Сжатие информацииСжатие происходит за счет устранения избыточности кода, например, за счет

например, за счет упрощения кодов, исключения из них постоянных

битов или представления повторяющихся символов в виде коэффициента повторения.
Важнейшая характеристика процесса сжатия – коэффициент сжатия.
Коэффициент сжатия – отношение объема исходного сообщения к объему сжатого.

Слайд 4 Алгоритмы сжатия
1. Равномерное сжатие с использованием кодов одной

Алгоритмы сжатия1. Равномерное сжатие с использованием кодов одной длины.Этот метод используется,

длины.
Этот метод используется, если в записи сообщения присутствует небольшая

часть алфавита.
2. Сжатие с использованием кодов переменной длины.
Сокращение объёма данных достигается за счёт замены часто встречающихся данных короткими кодовыми словами, а редких — длинными.

Слайд 5 Сжатие с использованием кодов переменной длины
В этом случае

Сжатие с использованием кодов переменной длиныВ этом случае возникает проблема отделения

возникает проблема отделения кодов символов друг от друга.
Решить

эту проблему позволяет условие, достаточное для однозначного декодирования сообщений с переменной длиной кодовых слов, условие Фано:
Никакое кодовое слово не является началом другого кодового слова.
По-другому условие Фано называют свойством префиксности, а код, удовлетворяющий этому условию, называют префиксным кодом.

Слайд 6 Префиксные коды
Чтобы понять, как строятся префиксные коды, рассмотрим,

Префиксные кодыЧтобы понять, как строятся префиксные коды, рассмотрим, как построить ориентированный

как построить ориентированный граф, определяющий этот код.
Например, кодовые

слова 00, 01, 10, 011, 100, 101, 1001, 1010, 1111, кодируют соответственно буквы: a, b, c, d, e, f, g, h, i.

Слайд 7 Префиксные коды
Построим граф этого кода.
Из начальной вершины выходят

Префиксные кодыПостроим граф этого кода.Из начальной вершины выходят две дуги, помеченные

две дуги, помеченные 0 и 1. Затем из конца

каждой такой дуги входят новые дуги, помеченные 0 и 1 так, чтобы, идя по этим дугам от корня, читалось начало какого-либо кодового слова.

Слайд 8 Префиксные коды
Если при этом какое-то последовательность оказывается прочитанным

Префиксные кодыЕсли при этом какое-то последовательность оказывается прочитанным полностью, то у

полностью, то у конца последней дуги пишется кодируемый символ.


Из получившихся вершин снова проводятся дуги — и так далее, до тех пор, пока не будут исчерпаны все коды.


Слайд 9 Префиксные коды
Если известен граф, созданный по префиксному коду,

Префиксные кодыЕсли известен граф, созданный по префиксному коду, то по этому

то по этому графу легко восстанавливается код каждого символа

— надо просто, идя от корня к листу, помеченному данным символом, выписать 0 и 1 в порядке их прочтения.
Идея префиксного кодирования была использована американским ученым Д.Хаффманом для создания эффективного алгоритма сжатия символьной информации. 

Слайд 10 Алгоритм Хаффмана
Алгоритм Хаффмана — адаптивный алгоритм оптимального  префиксного кодирования алфавита с минимальной

Алгоритм ХаффманаАлгоритм Хаффмана — адаптивный алгоритм оптимального   префиксного кодирования алфавита с минимальной избыточностью. Был разработан 1952 году аспирантом Массачусетского

избыточностью.
Был разработан 1952 году аспирантом Массачусетского технологического института Дэвидом Хаффманом при написании им

курсовой работы. В настоящее время используется во многих программах сжатия данных.

Слайд 11 1. Символы исходного алфавита образуют вершины. Вес каждой

1. Символы исходного алфавита образуют вершины. Вес каждой вершины вес равен

вершины вес равен количеству вхождений данного символа в сжимаемое

сообщение.
2. Среди вершин выбираются две с наименьшими весами (если таких пар несколько, выбирается любая из них).
3. Создается следующая вершина графа, из которой выходят две дуги к выбранным вершинам; одна дуга помечается цифрой 0, другая — символом 1.
Вес созданной вершины равен сумме весов, выбранных на втором шаге вершин.
4. К новым вершинам применяются шаги 2 и 3 до тех пор, пока не останется одна вершина с весом, равным сумме весов исходных символов.

Слайд 12 НА_ДВОРЕ_ТРАВА,_НА_ТРАВЕ_ДРОВА
Составим таблицу кодов символов:

НА_ДВОРЕ_ТРАВА,_НА_ТРАВЕ_ДРОВА Составим таблицу кодов символов:

Слайд 13 Найдем объем сообщения после кодирования кодом Хаффмана: 2·6

Найдем объем сообщения после кодирования кодом Хаффмана: 2·6 + 3·4 +

+ 3·4 + 4·2 + 4·1 + 4·2 +

4·2 + 3·4 + 4·2 + 4·2 + 3·5 = 95 бит.
Теперь подсчитаем объем этого сообщения, если каждый его символ кодировать цепочкой из 0 и 1 равной длины. Т.к. в сообщении 10 различных символов вес одного символа 4 бита. Поэтому после кодирования получится сообщение объемом 4·3 = 120 бит.
Коэффициент сжатия равен 120/95 =1,26.
Сообщение в памяти компьютера закодировано с помощью ASCII-кодов, каждый символ весит 8 бит. Значит, объем исходного сообщения 240 бит.
Коэффициент сжатия равен 240/95 = 2,53. 

Слайд 14 Математики доказали, что среди алгоритмов, кодирующих каждый символ

Математики доказали, что среди алгоритмов, кодирующих каждый символ по отдельности и

по отдельности и целым количеством бит, алгоритм Хаффмана обеспечивает

наилучшее сжатие.

Слайд 15 Для кодирования сообщения, состоящего из букв А, Б,

Для кодирования сообщения, состоящего из букв А, Б, В, Г и

В, Г и Д, используется неравномерный двоичный код, позволяющий

однозначно декодировать полученную двоичную последовательность.
А–00, Б–010, В–011, Г–101, Д–111.
Можно ли сократить для одной из букв длину кодового слова так, чтобы код по-прежнему можно было декодировать однозначно?
Выберите правильный вариант ответа.
1) для буквы Б – 01 2) это невозможно
3) для буквы В – 01 4) для буквы Г – 01

Задача А9


Слайд 16 Задача А9. Решение.
Построим двоичное дерево, в котором от

Задача А9. Решение.Построим двоичное дерево, в котором от каждого узла отходит

каждого узла отходит две ветки: 0 или 1.
Разместим на

дереве буквы А, Б, В, Г и Д так, чтобы их код получался как последовательность чисел на рёбрах:

Слайд 17 Задача А9. Решение.
По дереву определим, что для букв

Задача А9. Решение.По дереву определим, что для букв Г и Д

Г и Д код можно сократить. Выберем ответ из

предложенных вариантов:
1) для буквы Б – 01 2) это невозможно
3) для буквы В – 01 4) для буквы Г – 01

Ответ: 4.


Слайд 18 Для передачи по каналу связи сообщения, состоящего только

Для передачи по каналу связи сообщения, состоящего только из букв А,

из букв А, Б, В, Г, решили использовать неравномерный

по длине код:
A=0, Б=10, В=110.
Как нужно закодировать букву Г, чтобы длина кода была минимальной и допускалось однозначное разбиение кодированного сообщения на буквы?
1) 1 2) 1110 3) 111 4) 11

Для самостоятельной работы


Слайд 19 Для 5 букв латинского алфавита заданы их двоичные

Для 5 букв латинского алфавита заданы их двоичные коды. Эти коды

коды.
Эти коды представлены в таблице:
Задача А9
Определить, какой набор

букв закодирован двоичной строкой 0110100011000

  • Имя файла: szhatie-informatsii-algoritm-haffmana.pptx
  • Количество просмотров: 128
  • Количество скачиваний: 0