Loading AI tools
Из Википедии, свободной энциклопедии
Zstandard — алгоритм сжатия данных без потерь, разрабатываемый с 2015 года Яном Колле (фр. Yann Collet) при поддержке корпорации Facebook; zstd — эталонная реализация алгоритма Zstandard на языке программирования Си под свободной лицензией BSD. Версия 1.0 алгоритма и реализации были представлены в конце августа 2016 года[5][6].
Zstandard | |
---|---|
Тип | библиотека функций и утилита командной строки[вд] |
Написана на | Си |
Операционные системы | GNU/Linux, BSD[вд] и Mac OS[вд] |
Последняя версия | |
Репозиторий | github.com/facebook/zstd… |
Лицензия | модифицированная лицензия BSD[вд][2][3] и GNU GPL 2[2][4] |
Сайт | facebook.github.io/… (англ.) |
Сочетает словарный алгоритм сжатия данных типа LZ77 и эффективное энтропийное кодирование типа ANS (FSE — Finite State Entropy), алгоритм, сходный с кодом Хаффмана, реализующий нецелое количество бит для хранения символов[7][8].
Целью разработки является достижение коэффициентов сжатия, сопоставимых или превосходящих классический алгоритм deflate (разработан в середине 1990-х, реализован в Zip, gzip и других) при более высокой скорости как сжатия, так и распаковки. Сходные цели решают алгоритмы Brotli (Google) и LZFSE[фр.] (Apple, также использует ANS FSE)[9].
По данным LTCB, zstd 0.6 при максимальной степени сжатия показывает уровень сжатия, близкий к архиваторам boz, yxz, tornado; более высокий, чем у lza, brotli, bzip2, обеспечивая при этом очень быструю распаковку (2,2 нс/байт на Core i7-3930K при 4,5 ГГц)[10]
Алгоритм реализует 22 уровня сжатия, различающихся скоростью и эффективностью (уровень «1» — самый быстрый, уровень «22» — более эффективный). Опционально алгоритм может проанализировать заданный набор данных для составления специализированных внешних словарей. Задаваемый пользователем словарь улучшает степень сжатия сходных файлов, но требуется при распаковке. Словари применяют для сжатия небольших файлов, имеющих общие наборы строк, например, XML-файлы[11][12].
Эталонная реализация алгоритма на Си распространяется под свободной лицензией BSD[13]. Код опубликован на сайте Github. Начиная с версии 1.3.1[14] из условий было убрано упоминание ограниченной патентной лицензии, а код был перелицензирован под условиями двойной BSD + GPLv2 лицензии[15].
Метод Zstandard включён в состав ядра Linux с версии 4.14 от ноября 2017 для использования в файловых системах, в частности, в btrfs и squashfs[16][17][18]. Также метод тестировался во FreeBSD для интеграции в файловую систему OpenZFS[19].
Алгоритм используется в ряде дата-центров и системах обработки «больших данных», в частности, в Amazon RedShift[20]. Поддерживается в базах данных, например RocksDB, в некоторых архиваторах, в частности, в FreeArc.
Описание метода Zstandard и MIME-тип «application/zstd» были поданы в IETF в качестве интернет-черновика[21].
Корпорация Canonical в дистрибутиве Ubuntu планирует перевести пакетный формат deb на сжатие при помощи zstd начиная с версии 18.10 (октябрь 2018) ради ускорения процесса установки примерно на 10 процентов. Сжатие пакетов при помощи Zstd на уровне 19 приводит к немного большему размеру пакета, чем при ранее использовавшемся алгоритме xz (LZMA), но zstd позволяет быстрее распаковывать[22][23].
Полноценная реализация алгоритма с выбором уровня сжатия используется в форматах .NSZ/.XCZ[24], разработанных homebrew-сообществом для гибридной игровой консоли Nintendo Switch[25][26].
Seamless Wikipedia browsing. On steroids.
Every time you click a link to Wikipedia, Wiktionary or Wikiquote in your browser's search results, it will show the modern Wikiwand interface.
Wikiwand extension is a five stars, simple, with minimum permission required to keep your browsing private, safe and transparent.