Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2005.06.14;
Скачать: CL | DM;

Вниз

Данные длиною в три байта.   Найти похожие ветки 

 
KilkennyCat ©   (2005-05-10 12:49) [0]

Можно ли такое реализовать?
Предположим, что куча записей базы данных имеют ссылку на другую базу. В этой другой базе записей не более $ffffff, то есть, в первой базе достаточно хранить ссылку размером в три байта. При миллионе записей в первой базе отсутствие одного байта - почти мегабайт экономии.


 
KilkennyCat ©   (2005-05-10 12:53) [1]

Прошу прощения, как-то пространно написал. Проще говоря, как считать (например, из файла) три байта и привести их к LongWord?


 
Marser ©   (2005-05-10 13:03) [2]

longwordvar:= firstbyte + secondbyte shl 8 + thirdbyte shl 16


 
GreatMaster   (2005-05-10 13:04) [3]

asm
xor  eax, eax
mov  al, число1
shl  eax, 16
mov  ah, число2
mov  al, число3

результат в eax :)


 
KilkennyCat ©   (2005-05-10 13:05) [4]

Спасибо.
Сейчас еще 0D0A выкину, и моя база будет самая малюсенькая! :)


 
Marser ©   (2005-05-10 13:08) [5]

Это пример приведения трёх байт к LongWord. Ну а считывать можено обратной операцией.
firstbyte:=lo(longwordvar);
secondbyte:=hi(longwordvar);
thirdbyte:=longwordvar shr 16


 
nikkie ©   (2005-05-10 13:12) [6]

мегабайт экономии, говоришь? на гигабайтной базе вряд ли заметишь. надо считать относительный выигрыш, а не абсолютный.


 
kai ©   (2005-05-10 13:13) [7]

KilkennyCat ©   (10.05.05 13:05) [4] Спасибо.
Сейчас еще 0D0A выкину, и моя база будет самая малюсенькая! :)

и самая медленная -)


 
KilkennyCat ©   (2005-05-10 13:17) [8]


> [5] Marser ©   (10.05.05 13:08)


ага, это я понял из [2], спасибо.


 
KilkennyCat ©   (2005-05-10 13:20) [9]


> [6] nikkie ©   (10.05.05 13:12)


Как сказать... Переделка KLADR таким макаром позволила с 7,72 М в архиве уменьшить до 2,5 М в архиве. Что уже существенно при скачивании в интернете.


> [7] kai ©   (10.05.05 13:13)


Быстрее, чем через BDE


 
GreatMaster   (2005-05-10 13:23) [10]

Marser, [2] даст не верный результат, если твои переменные байтовые! (firstbyte, secondbyte, thirdbyte : byte;)
надо по очереди сдвигать:
 a:=1;
 a:=a shl 8;
 a:=a + 2;
 a:=a shl 8;
 a:=a + 3;


 
Anatoly Podgoretsky ©   (2005-05-10 13:32) [11]

KilkennyCat ©   (10.05.05 12:49)  
Ты гораздо больше выиграешь если объединишь эти две базы.


 
nikkie ©   (2005-05-10 13:38) [12]

>с 7,72 М в архиве уменьшить до 2,5 М в архиве
в 3 раза за счет удаления 1 байта из 4-х?
даже если других данных в базе нет - выигрыш только 25% будет, а не 66%.
что-то мне с трудом верится.


 
KilkennyCat ©   (2005-05-10 13:43) [13]


> Anatoly Podgoretsky ©   (10.05.05 13:32) [11]


Нет, при объединении я буду вынужден вместо трех байтов добавить намного больше.


> nikkie ©   (10.05.05 13:38) [12]


Это не единственная оптимизация.


 
GreatMaster   (2005-05-10 13:54) [14]

Держи SmallInt + Byte
ещё и за счёт служебных данных пару бит выиграешь :)


 
nikkie ©   (2005-05-10 14:11) [15]

>Это не единственная оптимизация.
вооот. осталось теперь оценить вклад именно этого момента в общий результат. сдается мне, что в этой базе есть также и текстовые данные, а потому вряд ли экономия одного байта даст более 1% выигрыша.


 
GreatMaster   (2005-05-10 14:33) [16]

голое поле номеров никому не нужно, тогда бы как Anatoly Podgoretsky сказал и всё.
ясный перец есть чёто ещё. это или такие же 3х байтовые поля-обрезки на другие/этуже таблицы, тогда изврат с 3мя байтами канает. Или просто обычные данные, тогда замутка ваще не в тему и выигрыш --> 0


 
KilkennyCat ©   (2005-05-10 14:50) [17]


> nikkie ©   (10.05.05 14:11) [15]


Да есть.

Ну раз уж заговорили оффтопом, давайте тогда расскажу вкратце структуру. Может, придем к выводу, что я фигню наворотил.
Итак, популярный KLADR имеет три основных файла:
KLADR.DBF, где находятся следующие мне интересные поля:
наименования городов, районов и пр. (string), код субъекта(byte), почтовый индекс (string[6]), окато(string[11]), код налоговой (string[4]), сокращенное наименование (string[1-10])
STREET.DBF c аналогичной структурой, DOMA.DBF, SOCR.DBF

В каждом есть еще громадное поле CODE (11, 15 и 23 байтов), которое все связывает.

Что сделал я - выдрал все поля и уничтожил дубликаты.
Получил в итоге семь файликов: файл связей, индексы, окато, гни, наименования, сокращенные наименования, расшифровка наименований.
Всего в дбэфах около миллиона записей (а ведь в каждой записи еще кучка полей...), объем базы около 50 метров (изначально было почти 70, но я выкинул ненужных полей немного :) ).

У меня:

файл - число записей - необходимый размер ссылки
DOMA  - 23911  -  2byte
INDEX - 40227  -  2byte
NAME  - 152028 -  3byte
SOCR  - 81     -  byte
SSOCR  - 81    -  ненужно
OKATO - 129128 -  3byte
Region - 99    -  byte
GNI   - 2493   -  2byte

итого, мой CODE имеет размер 14 байт.

число записей файла связей около 600 тысяч.

все файлы в несжатом виде имеют размер около 11 метров

Сделав NАМЕ и ОКАТО на один байт меньше, я выиграл чуть больше мегабайта. Заменив $0D0A на $00 я выиграю еще почти 0,4 метра

Проигрыш в работе только лишь при первоначальной загрузке. И вполне терпимый, по крайней мере, я это торможение (4 секунды) заметил лишь на Pentium-II-300


 
KilkennyCat ©   (2005-05-10 14:52) [18]

Согласитесь, отобрать у 11 метров еще полтора - это неплохо.
Но это еще не конец: файл связей вполне поддается алгоритмизации, а не тупой прописи. Ща еще уменьшу вполовину.


 
nikkie ©   (2005-05-10 16:23) [19]

>объем базы около 50 метров
>все файлы в несжатом виде имеют размер около 11 метров
если честно, то я не понимаю.

>итого, мой CODE имеет размер 14 байт.
>число записей файла связей около 600 тысяч.
видимо один файл CODE весил 11Mb? его удалось сократить на 1/8 (2 байта из 16). ок. а что с остальными 40Mb?


 
KilkennyCat ©   (2005-05-10 16:34) [20]


> nikkie ©   (10.05.05 16:23) [19]


остальные - это структура dbf и многократно, сверхмногократно повторяющиеся значения.


 
nikkie ©   (2005-05-10 16:50) [21]

если кто-нибудь понял, объясните мне.


 
KilkennyCat ©   (2005-05-10 17:33) [22]


> nikkie ©   (10.05.05 16:50) [21]


гм...

ну вот, к примеру имеем таблицу. Стандартно, как в книжке :) - три отдела сотрудников, фио сотрудников, номер телефона сотрудников. Но телефон на всю контору - один единственный и фио1 работает сразу в двух...
Так вот кладр был бы так:

отдел1 фио1 телефон1
отдел1 фио2 телефон1
отдел2 фио1 телефон1

у меня же было бы так:

файл с пятью записями отдел1, отдел2 , фио1 , фио2, телефон1
и файл связей, реализовавший бы первоначальную таблицу.

ну вот опять из статистики: почтовый индекс в кладре реализован как строка из 6 байтов и пишется в каждой записи, которых более миллиона. Но на самом деле почтовый индекс можно выразить всего тремя байтами, и всех вариантов индекса будет 999999*3 = 2,8 метра. Однако, так как вместо индекса мы вынуждены поставить идентификатор, то выигрыша никакого. Но! всего вариантов индекса 40227, т.е максимальный объем около 300 килобайт, и тогда мы получаем уменьшение объема индексов в таблице в два раза + 300 кил. Фактически с 5.7 метров до 3 метров.


 
KilkennyCat ©   (2005-05-10 17:36) [23]

Кстати, связи имеют четкую древовидную структуру. Это позволяет опять их оптимизировать по объему и значительно по скорости работы, так как на поиск подчиненых объектов уже не требуется полный перебор.
Да здравствует мой вариант КЛАДРа! :)



Страницы: 1 вся ветка

Текущий архив: 2005.06.14;
Скачать: CL | DM;

Наверх




Память: 0.5 MB
Время: 0.037 c
1-1117529916
voron
2005-05-31 12:58
2005.06.14
математика


1-1117467430
Dezo
2005-05-30 19:37
2005.06.14
Массив array of variant


4-1114164757
VVV-First
2005-04-22 14:12
2005.06.14
Memory Mapped Files


11-1100179003
<Falcon>
2004-11-11 16:16
2005.06.14
Стабильность работы МСК


4-1114421513
Jolik
2005-04-25 13:31
2005.06.14
Какое сообщение приходит при...





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский