eGospodarka.pl
eGospodarka.pl poleca

eGospodarka.plGrupypl.comp.programmingLiczby całkowite zmiennej długości › Re: Liczby całkowite zmiennej długości
  • Path: news-archive.icm.edu.pl!agh.edu.pl!news.agh.edu.pl!newsfeed2.atman.pl!newsfeed.
    atman.pl!.POSTED!not-for-mail
    From: Borneq <b...@a...hidden.pl>
    Newsgroups: pl.comp.programming
    Subject: Re: Liczby całkowite zmiennej długości
    Date: Wed, 30 Apr 2014 00:47:56 +0200
    Organization: ATMAN - ATM S.A.
    Lines: 40
    Message-ID: <ljpa7n$c50$1@node1.news.atman.pl>
    References: <ljou5f$uob$1@node1.news.atman.pl> <ljp492$5ug$1@node1.news.atman.pl>
    NNTP-Posting-Host: 91.239.205.62
    Mime-Version: 1.0
    Content-Type: text/plain; charset=UTF-8; format=flowed
    Content-Transfer-Encoding: 8bit
    X-Trace: node1.news.atman.pl 1398811703 12448 91.239.205.62 (29 Apr 2014 22:48:23
    GMT)
    X-Complaints-To: u...@a...pl
    NNTP-Posting-Date: Tue, 29 Apr 2014 22:48:23 +0000 (UTC)
    User-Agent: Mozilla/5.0 (Windows NT 6.3; WOW64; rv:24.0) Gecko/20100101
    Thunderbird/24.4.0
    In-Reply-To: <ljp492$5ug$1@node1.news.atman.pl>
    Xref: news-archive.icm.edu.pl pl.comp.programming:205525
    [ ukryj nagłówki ]

    W dniu 2014-04-29 23:05, bartekltg pisze:
    > Liczby średnio dwucyfrowe
    > http://huffman.ooz.ie/?text=0123456789KKKKK
    > (na każde dwie liczby przypada jeden konec linii)
    > mamy 5.8 bita, kontra 8 we wcześniejszej metodzie.
    > http://www.wolframalpha.com/input/?i=%284*8%2B2*3%29
    %2F10%2B2

    Dla zer i jedynek jest
    http://huffman.ooz.ie/?text=101010100K0110010K010101
    0100K
    K ma dwa bity, ale i jedynka, której jest połowa ilości ma dwa bity.
    Można by rozpatrywać kodowanie arytmetyczne, ale jeszcze bardziej
    komplikuje, są działania na wielkich liczbach.
    Do czego to ma być użyte: w pliku binarnym są przechowywane współrzędne
    linii łamanych w ten sposób, że pierwszy punkt jest przechowywany
    normalnie (ewentualnie później optymalizacje), następne punkty
    przechowywane są w postaci różnic, dzięki czemu liczba, która
    przechowywana jest z dokładnością 32 bitową, ma różnice rzędu
    najczęściej 300-2000. Liczby mogą być ujemne, więc stosuję metodę
    zygzakową ustawiając kolejno: 0,-1,1,-2,2,-3,3...
    Liczby mieszczą się najczęściej w dwóch bajtach, mając ilość bitów
    10-15, najczęściej 11-12.
    Można to zrobić tak (już przed laty stosowałem ten sposób), że mając
    osobno (choć niekoniecznie) dla współrzędnej X i Y patrzę na deltę,
    która wymaga najwięcej bitów np. 14, zapisuję tę liczbę i wszystkie
    pozostałe delty zapisuję na takiej samej ilości bitów. To ma wadę, bo
    wiele wartości może mieć np. 11 bitów a jedna 15 to wszystkie będą
    wymagały 15-tu.

    Można by trochę pokombinować: Niektóre delty są <= średnia długość a
    niektóre większe. Większe zapisywać z maksymalną długością, mniejsze z
    maksymalną długością małych. Niestety, trzeba by rozróżnić które są
    mniejsze a które większe czyli dla każdej delty jeden bit, co powoduje
    że ten sposób nie jest wiele lepszy niż z użyciem maksymalnej wartości.
    Tylko trochę mi się nie podoba - mogą wszystkie delty być malutkie a
    jedna ogromna i to psuje kodowanie, na szczęście takie nie występują
    zbyt często i strata jest średnio dla przykładu 2.6 bita dla średnio
    11.5 bitowej liczby czyli 22.6 %.



Podziel się

Poleć ten post znajomemu poleć

Wydrukuj ten post drukuj


Następne wpisy z tego wątku

Najnowsze wątki z tej grupy


Najnowsze wątki

Szukaj w grupach

Eksperci egospodarka.pl

1 1 1

Wpisz nazwę miasta, dla którego chcesz znaleźć jednostkę ZUS.

Wzory dokumentów

Bezpłatne wzory dokumentów i formularzy.
Wyszukaj i pobierz za darmo: