реклама на сайте
подробности

 
 
> Архиватор в микроконтроллере с малым требованием к ресурсам, сделать в МК архив, который на PC можно будет штатно разжать
Ruslan1
сообщение Nov 22 2016, 08:58
Сообщение #1


Гуру
******

Группа: Свой
Сообщений: 2 360
Регистрация: 6-03-06
Из: Кишинев
Пользователь №: 15 025



Здравствуйте!

Имеется кучка файлов, которые можно поделить на две группы
1) длинные текстовые- например, лог 6 мегабайт ежедневно
2) куча коротких текстовых - например, ежедневно директория с 1440 файлами по 200 байт (ежеминутные данные)

Хочу их заархивировать с целью:
группа1 - чтобы уменьшить размер (важно при передаче)
группа2 - чтобы уменьшить количество файлов, просто склейка в один файл без сжатия уже подходит (то есть что-то типа tar уже достаточно) - важно для хранения.

Архивация происходит периодически и не в реальном времени- например, раз в сутки для уже собранных файлов. То есть изменять архив не нужно и скорость работы функции не важна, фоновая задача.
Обязательное требование- чтобы на компьютере это можно было разжать, используя доступные в интернете стандартные архиваторы, а не писать свой распаковщик. Я точно не буду применять архиватор в нестандартный архив.
И еще крайне желательно, чтобы задача не требовала больших объемов памяти (временных буферов) во время работы. При этом скорость работы практически не важна.


Вопрос: есть ли примеры решения таких задач? аппноты какие-нибудь, блоги, линки....
Обычно на МК решается обратная задача - разжать (прошивку, образ итд), да и то из нестандартного формата, а вот упаковщики в "стандартный" архив как-то не попадаются.

Ни и если кто-то может рассказать про личный опыт, что за архиватор применяли на МК, буду безмерно счастлив.

конкретно буду реализовывать на STM32F4, если это важно
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
aiwa
сообщение Nov 22 2016, 12:20
Сообщение #2


Местный
***

Группа: Участник
Сообщений: 301
Регистрация: 13-12-15
Из: Харьков
Пользователь №: 89 682



minilzo
(__http://www.oberhumer.com/opensource/lzo/)
Go to the top of the page
 
+Quote Post
Ruslan1
сообщение Nov 22 2016, 13:03
Сообщение #3


Гуру
******

Группа: Свой
Сообщений: 2 360
Регистрация: 6-03-06
Из: Кишинев
Пользователь №: 15 025



Цитата(aiwa @ Nov 22 2016, 14:20) *
minilzo
(__http://www.oberhumer.com/opensource/lzo/)

Спасибо, буду думать (делать планирую буду ближе к новому году или даже после, чуть времени есть).
Все идет к тому что если хочу стандартный (zip какой-нить) то нужно больше усилий чем для нестандартного.
В принципе, наверное возможно и нестандарт, если разница в ресурсах велика....
в-общем-то оборудование небытовое, думаю смогу аргументировать применение и какого-нить небытового lzo.

Цитата(AlexandrY @ Nov 22 2016, 14:51) *
Все эти алгоритмы параметрезированы. Распаковщики эту параметризацию понимают. Поэтому вы полностью управляете ресурсами. Любой засунете в пару десятков килобайт.
Дело только в том что сжатие такое дело, что чем меньше памяти под словари тем хуже сжатие.

Но TC скорее нужен не алгоритм сжатия, а формат контейнеров. Это другая тема.
Мои zip файлы компьютер понимает, но контейнер для многих файлов в одном zip-е я не делал.

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

Причем прямо сейчас контейнер более востребован чем сжиматель. Неужто tar сложный формат, я почему-то думал что там не так все сложно.

А свой нестандартный последний сжиматель я еще в институте делал, по Хафману, на Z80 и ассемблере. Для курсовой сжимателя хватило, разжиматель пусть другие делают sm.gif
Go to the top of the page
 
+Quote Post
HardEgor
сообщение Nov 22 2016, 13:48
Сообщение #4


Гуру
******

Группа: Свой
Сообщений: 2 223
Регистрация: 3-03-06
Из: Tomsk
Пользователь №: 14 925



Цитата(Ruslan1 @ Nov 22 2016, 20:03) *
Причем прямо сейчас контейнер более востребован чем сжиматель. Неужто tar сложный формат, я почему-то думал что там не так все сложно.

tar это вообще элементарщина, был придуман чтобы потоково лить файлы на ленту.
Просто все привыкли что сейчас он еще заворачивается в gzip, вот и переживают...

Вообще по-хорошему надо найти исходники самого древнего unix - там будет и tar и gzip для минимальных ресурсов.
Go to the top of the page
 
+Quote Post
Ruslan1
сообщение Nov 22 2016, 17:09
Сообщение #5


Гуру
******

Группа: Свой
Сообщений: 2 360
Регистрация: 6-03-06
Из: Кишинев
Пользователь №: 15 025



Цитата(HardEgor @ Nov 22 2016, 15:48) *
tar это вообще элементарщина, был придуман чтобы потоково лить файлы на ленту.
Просто все привыкли что сейчас он еще заворачивается в gzip, вот и переживают...

Вообще по-хорошему надо найти исходники самого древнего unix - там будет и tar и gzip для минимальных ресурсов.

Да, я на это и надеялся, просто не открывал совсем, боялся испугаться sm.gif
а как открыл, так просветлел сильно и сразу. может кому еще пригодится, тут ссылки оставлю:
этого и этого, по-моему, вполне хватит для написания своего тара.

ну и просто обсуждение : тут и тут про тар "на пальцах на русском"

В-общем, спасибо огромное, с контейнером все понятно, красиво и просто, и непонятно что тут "ресурсами" называть sm.gif
а это была более срочная часть роботы, чем сжиматель, так что вдвойне приятно.- сделаю это, а сжиматель потом, он не так приоритетен

Осталось понять что со сжимателем делать, но теперь это совсем не срочно.

Цитата(SasaVitebsk @ Nov 22 2016, 18:47) *
Глупости. На меге делал модем. Там было сжатие. Примерно 2 коэффициент. Сжатие в потоке даже с адаптивным словарём очень мало рерурсов ест. А распаковка - вообще 0. На CM3 даже не заметишь.
Существенный выигрыш получается при увеличении размера словаря и если словарь предопределён, до начала сжатия.

Что именно использовали на Меге, какой упаковщик?

у меня файл завершен и записан на диск, и времени много. Могу хоть 10 раз его перечитать если это для составления и корректировки полного словаря нужно. Но вот RAM хотелось бы экономить.
Адаптивный словарь меня скорее всего тоже устроит. Текст, причем только нижняя половина ASCII, много похожих строк. То есть по малой части текста можно очень неплохо подходящий всему тексту словарь сделать. Zip эти 6 мегабайт жмет в 10 раз (на минимальной степени сжатия, 1), на максимальной (9) - в 15 раз жмет.
Go to the top of the page
 
+Quote Post

Сообщений в этой теме
- Ruslan1   Архиватор в микроконтроллере с малым требованием к ресурсам   Nov 22 2016, 08:58
- - Огурцов   есть же какой-то зип открытый, только возьми и ско...   Nov 22 2016, 09:18
- - AlexandrY   Цитата(Ruslan1 @ Nov 22 2016, 10:58) Я то...   Nov 22 2016, 09:40
|- - Ruslan1   Цитата(AlexandrY @ Nov 22 2016, 11:40) Те...   Nov 22 2016, 10:50
|- - SasaVitebsk   Цитата(AlexandrY @ Nov 22 2016, 12:40) Но...   Nov 22 2016, 16:47
|- - AlexandrY   Цитата(SasaVitebsk @ Nov 22 2016, 18:47) ...   Nov 22 2016, 17:10
|- - blackfin   Цитата(Ruslan1 @ Nov 22 2016, 16:03) Все ...   Nov 22 2016, 19:19
- - vladec   zip-ы, rar-ы, tar-ы и т.п. требуют для своей работ...   Nov 22 2016, 12:39
|- - AlexandrY   Цитата(vladec @ Nov 22 2016, 14:39) zip-ы...   Nov 22 2016, 12:51
- - SasaVitebsk   Речь шла о текстовом документе. Скажем так. Пробов...   Nov 22 2016, 19:06
|- - Ruslan1   Цитата(SasaVitebsk @ Nov 22 2016, 21:06) ...   Nov 22 2016, 19:14
|- - SasaVitebsk   Цитата(Ruslan1 @ Nov 22 2016, 22:14) ...   Nov 22 2016, 19:19
- - makc   Посмотрите на https://github.com/atomicobject/heat...   Nov 22 2016, 20:25
|- - AlexandrY   Цитата(makc @ Nov 22 2016, 22:25) Посмотр...   Nov 22 2016, 21:38
|- - Ruslan1   Хм. Или никто не знает, или посчитали несущественн...   Nov 24 2016, 23:38
|- - makc   Цитата(AlexandrY @ Nov 23 2016, 00:38) Хо...   Nov 25 2016, 03:46
- - k155la3   Архиватору требуется большой объем памяти для анал...   Nov 25 2016, 07:17
|- - Ruslan1   Про контейнер- альтернативу использованию тара. Ка...   Nov 25 2016, 09:13
|- - ViKo   Цитата(Ruslan1 @ Nov 25 2016, 12:13) Сейч...   Nov 25 2016, 10:00
|- - Ruslan1   Цитата(ViKo @ Nov 25 2016, 12:00) 10 * 17...   Nov 25 2016, 10:15
|- - ViKo   Цитата(Ruslan1 @ Nov 25 2016, 13:15) ViKo...   Nov 25 2016, 10:23
||- - Ruslan1   Цитата(ViKo @ Nov 25 2016, 12:23) В вашем...   Nov 25 2016, 10:55
||- - ViKo   Цитата(Ruslan1 @ Nov 25 2016, 13:55) Вы, ...   Nov 25 2016, 11:20
|||- - Ruslan1   Цитата(ViKo @ Nov 25 2016, 13:20) Понятно...   Nov 25 2016, 12:45
||- - AlexandrY   Цитата(Ruslan1 @ Nov 25 2016, 12:55) Вы, ...   Nov 25 2016, 11:24
|||- - Ruslan1   Цитата(AlexandrY @ Nov 25 2016, 13:24) Чт...   Nov 25 2016, 11:42
||- - mantech   Цитата(Ruslan1 @ Nov 25 2016, 13:55) Вы, ...   Nov 25 2016, 13:36
|- - gerber   Цитата(Ruslan1 @ Nov 25 2016, 13:15) Не, ...   Nov 25 2016, 10:34
|- - Ruslan1   Цитата(gerber @ Nov 25 2016, 12:34) Ну и ...   Nov 25 2016, 20:24
|- - Ruslan1   В-общем, реализовал tar с дописыванием в архив нов...   Nov 27 2016, 23:13
- - gerber   Ещё ISO есть.   Nov 25 2016, 09:21
- - firew0rker   Я применила для такой задачи (сбор и ежесуточное а...   Dec 7 2016, 03:29
|- - Alechek   Цитата(firew0rker @ Dec 7 2016, 08:29) Дл...   Dec 7 2016, 05:15
- - firew0rker   Так мне и надо было распаковать 1 файл на МК. Если...   Dec 7 2016, 06:27
- - AlexandrY   Цитата(firew0rker @ Dec 7 2016, 08:27) Ес...   Dec 7 2016, 06:55
- - firew0rker   Цитата(AlexandrY @ Dec 7 2016, 13:55) Пок...   Dec 7 2016, 08:43
- - AlexandrY   Цитата(firew0rker @ Dec 7 2016, 10:43) mi...   Dec 7 2016, 09:32
- - firew0rker   Цитата(AlexandrY @ Dec 7 2016, 16:32) Да ...   Dec 7 2016, 13:04
- - Ruslan1   Спасибо, но на линукс ради архиватора переходить н...   Dec 7 2016, 19:58
- - jcxz   Цитата(Ruslan1 @ Dec 7 2016, 22:58) У мен...   Jan 3 2017, 16:50
- - Ruslan1   Цитата(jcxz @ Jan 3 2017, 18:50) Как я по...   Jan 3 2017, 19:30


Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 20th July 2025 - 21:38
Рейтинг@Mail.ru


Страница сгенерированна за 0.01456 секунд с 7
ELECTRONIX ©2004-2016