> aritmetisk kodning | brøkbits | optimal <

// Aritmetisk kodning - kodning med brøkbits tæt på entropigrænsen

[OPTIMAL]

Næsten optimal

Nærmer sig den teoretiske entropigrænse for komprimeringseffektivitet.

[FRACTIONAL]

Brøkbits

Koder symboler med brøkdele af bits baseret på sandsynlighed.

[STREAMING]

Streaming

Kan kode og dekode data løbende, efterhånden som de ankommer.

>> tekniske detaljer

Sådan fungerer aritmetisk kodning:

Aritmetisk kodning repræsenterer en hel besked som ét tal i intervallet [0,1). Hvert symbol indsnævrer intervallet baseret på dets sandsynlighed. Det endelige interval kodes som en binær brøk og giver komprimering meget tæt på entropigrænsen.

Kodningsforløb:

Tekst: "AAB" Sandsynligheder: A=0.67, B=0.33 1. Start: [0, 1) 2. 'A': [0, 0.67) 3. 'A': [0, 0.45) 4. 'B': [0.30, 0.45) Output: Et vilkårligt tal i [0.30, 0.45) Binær: 0.010011...

Hvorfor bruge aritmetisk kodning:

  • >Bedste komprimeringsforhold
  • >Nærmer sig entropigrænsen
  • >Håndterer vilkårlige sandsynligheder
  • >Bruges i JPEG2000/H.264
  • >Patenter udløbet (2024)

>> ofte stillede spørgsmål

Hvad er aritmetisk kodning?

Aritmetisk kodning er en form for entropikodning, der omdanner en sekvens af symboler til ét brøktal. I modsætning til Huffman-kodning, som bruger hele bits, kan aritmetisk kodning bruge brøkbits pr. symbol.

Hvorfor er den bedre end Huffman?

Aritmetisk kodning kan opnå komprimering vilkårligt tæt på entropigrænsen, mens Huffman er begrænset til hele bits pr. symbol. Ved stærkt skæve sandsynligheder kan aritmetisk kodning være markant bedre.

Hvad er præcisions-parameteren?

Præcision styrer antallet af bits, der bruges til interne beregninger. Højere præcision gør det muligt at kode længere beskeder, men kræver mere hukommelse. 16 bit er normalt nok til korte tekster.

Hvor bruges aritmetisk kodning?

Aritmetisk kodning bruges i moderne komprimeringsstandarder som H.264/H.265-video, JPEG2000-billeder og ZIPs DEFLATE64. Den var tidligere dækket af patenter, men de vigtigste er udløbet.

Andre sprog