МИНОБРНАУКИ РОССИИ САНКТ-ПЕТЕРБУРГСКИЙ ГОСУДАРСТВЕННЫЙ ЭЛЕКТРОТЕХНИЧЕСКИЙ УНИВЕРСИТЕТ «ЛЭТИ» ИМ. В.И. УЛЬЯНОВА (ЛЕНИНА) Кафедра информационных систем ОТЧЕТ по практической работе №6 по дисциплине «Теория информации, данные, знания» Тема: Эффективное кодирование. Код Хаффмана Студент(ка) гр. 0323 Пришивалко ВН Преподаватель Писарев И. А. Санкт-Петербург 2022 2. Задание 2.1. Письменно ответить на вопросы. 1. Опишите метод Хаффмана. 2. Какие существуют другие методы кодирования ? Дайте их сравнительную характеристику 3. Укажите правильный вариант ответа. «Если взять два наименее вероятне символа в алфавите, эти два символа получат кодовые слова с максимальной длиной, отличающиеся: вариант отчета 1: последним символом вариант отчета 2: первым символом» 2.2. Решить задачи 1. Закодировать сообщение методом Хаффмана сообщение 1 вероятность 0,3 2 3 4 5 6 7 0,2 0,2 0,1 0,1 0,05 0,05 2. Алфавит содержит 7 букв, которые встречаются с вероятностями 0,4; 0,2; 0,1; 0,1; 0,1; 0,05; 0,05. Осуществите кодирование по методу Хаффмана 2 Выполнение работы Ответы на вопросы: 1. 1. Взять два наименее вероятных символа в алфавите. Эти два символа получат кодовые слова с максимальной длиной, отличающиеся последним символом. 2. Объединить два символа в один, повторить 1. Кодируемые знаки, также как при использовании метода Шеннона-Фано, располагают в порядке убывания их вероятностей (таблица 7). Далее на каждом этапе две последние позиции списка заменяются одной и ей приписывают вероятность, равную сумме вероятностей заменяемых позиций. После этого производится пересортировка списка по убыванию вероятностей, с сохранением информации о том, какие именно знаки объединялись на каждом этапе. Процесс продолжается до тех пор, пока не останется единственная позиция с вероятностью, равной 1. После этого строится кодовое дерево. Корню дерева ставится в соответствие узел с вероятностью, равной 1. Далее каждому узлу приписываются два потомка с вероятностями, которые участвовали в формировании значения вероятности обрабатываемого узла. Так продолжают до достижения узлов, соответствующих вероятностям исходных знаков Процесс кодирования по кодовому дереву осуществляется следующим образом. Одной из ветвей, выходящей из каждого узла, например, с более высокой вероятностью, ставится в соответствие символ 1, а с меньшей – 0. Спуск от корня к нужному знаку дает код этого знака. Правило кодирования в случае равных вероятностей оговаривается особо. Таблица 7 и рисунок 10 иллюстрируют применение методики Хаффмана. [1, с.58-59] 3 2. * Кодирование Шеннона (от наиболее вероятного к наименее вероятному) * Метод Шеннона-Фано (разбиение на две группы с близкими друг другу вероятностями) * Блочное кодирование (применяется при избыточности кода) * Арифметическое кодирование (алгоритм сжатия текста без потерь) * Декодирование (алгоритм восстанавливает исходный текст) [1, с.58-62] 3. Последним символом Задачи: 1. Закодировать сообщение методом Хаффмана сообщение 1 вероятность 0,3 2 3 4 5 6 7 0,2 0,2 0,1 0,1 0,05 0,05 Процесс кодирования 𝒂𝒊 𝒑𝒊 1 0,3 0,3 0,3 0,3 0,4 0,6 2 0,2 0,2 0,2 0,3 0,3 0,4 3 0,2 0,2 0,2 0,2 0,3 4 0,1 0,1 0,2 0,2 5 0,1 0,1 0,1 6 0,05 0,1 7 0,05 1 Код 10 00 01 110 1110 11111 11110 4 2. СПИСОК ИСПОЛЬЗОВАННЫХ ИСТОЧНИКОВ Стр. 57-62. Гошин Е.В. Теория информации и кодирования. Самара: Самарский университет, 2018 — 124 с. 5