JPEG | |
---|---|
Laajennus | .jpg, .jpeg, .JPG, .JPEG, .jpetai.JPE |
MIME -tyyppinen | kuva/jpeg |
Allekirjoitus | 0xFF 0xD8 |
julkaistu | 18. syyskuuta 1992 |
Muototyyppi | Graafinen muoto |
Kehitetty vuonna | JPEG 2000 , JPEG-LS , JPEG XR , MotionJPEG |
Standardit) | ISO/IEC 10918 |
Verkkosivusto | jpeg.org/jpeg/ ( englanti) |
Mediatiedostot Wikimedia Commonsissa |
JPEG (lausutaan jpeg [1] , eng . Joint Photographic Experts Group , kehittäjäorganisaation nimen mukaan ) on yksi suosituimmista rasterigrafiikkaformaateista , joita käytetään valokuvien ja vastaavien kuvien tallentamiseen. JPEG-tietoja sisältävien tiedostojen pääte (liitteet) on yleensä .jpg ( suosituin ), .jfif , .jpe tai .jpeg . MIME- tyyppi on image/jpeg.
JPEG-algoritmin avulla voit pakata kuvan sekä häviöttömällä että häviöttömällä ( häviötön JPEG-pakkaustila). Kuvia, joiden lineaarinen koko on enintään 65535 × 65535 pikseliä, tuetaan.
Säilyttääkseen jälkipolville tietoa 2000-luvun alussa suosituista digitaalisista formaateista PLANETS-projektin tutkijat asettivat ohjeet JPEG-muodon lukemiseksi erityiseen kapseliin, joka sijoitettiin erityiseen arkistoon Sveitsin Alpeilla. [2] .
JPEG-algoritmi on tehokkain pakkaamaan valokuvia ja maalauksia, jotka sisältävät realistisia kohtauksia tasaisilla kirkkauden ja värien siirtymillä. JPEG on laajimmin käytetty digitaalisessa valokuvauksessa sekä kuvien tallentamiseen ja lähettämiseen Internetin avulla .
JPEG-muodosta häviöisessä pakkaustilassa ei ole juurikaan hyötyä piirustusten, tekstin ja merkkigrafiikan pakkaamisessa, jossa vierekkäisten pikselien välinen terävä kontrasti johtaa havaittaviin artefakteihin . On suositeltavaa tallentaa tällaiset kuvat häviöttömässä muodossa, kuten JPEG-LS , TIFF , GIF , PNG , tai käyttää häviötöntä JPEG-pakkaustilaa.
JPEG (sekä muut häviölliset pakkausmuodot ) ei sovellu kuvien pakkaamiseen monivaiheisen käsittelyn aikana, koska kuviin tulee vääristymiä joka kerta, kun käsittelyn välitulokset tallennetaan.
JPEG-tiedostoa ei tule käyttää tapauksissa, joissa pienikin häviö ei ole hyväksyttävää, kuten pakkaattaessa tähtitieteellisiä tai lääketieteellisiä kuvia. Tällaisissa tapauksissa JPEG-standardin (jota useimmat suositut koodekit eivät tue ) tai JPEG-LS- pakkausstandardin tarjoamaa häviötöntä JPEG-pakkaustilaa voidaan suositella .
Pakattuna kuva muunnetaan RGB-väriavaruudesta YCbCr :ksi . JPEG-standardi (ISO / IEC 10918-1) ei säätele YCbCr:n valintaa, mikä mahdollistaa muun tyyppisen muunnoksen (esimerkiksi komponenttien lukumäärällä [3] eri kuin kolmella) ja pakkaamisen ilman muuntamista (suoraan RGB:ksi). Kuitenkin JFIF-spesifikaatio (JPEG File Interchange Format, jota C-Cube Microsystems ehdotti vuonna 1991 ja nyt de facto standardi) sisältää RGB-> YCbCr-muunnoksen käytön.
RGB->YCbCr-muunnoksen jälkeen väreistä vastaaville Cb- ja Cr-kuvakanaville voidaan suorittaa "desimaatio" (alinäytteenotto [4] ), mikä tarkoittaa, että Y-kirkkauskanavan jokainen 4 pikselin (2x2) lohko on määritetty. keskimääräiset Cb- ja Cr-arvot (desimaatiokaavio "4:2:0" [5] ). Samanaikaisesti jokaiselle 2x2-lohkolle käytetään 12 arvon (4 Y, 4 Cb ja 4 Cr) sijasta vain 6:ta (4 Y ja yksi keskiarvotettu Cb ja Cr kumpikin). Jos pakkaamisen jälkeen palautetun kuvan laadulle on korkeammat vaatimukset, ohennus voidaan suorittaa vain yhteen suuntaan - pystysuoraan ("4:4:0" -malli) tai vaakasuoraan ("4:2:2") tai ei suoriteta. ollenkaan ("4:4:4").
Standardi sallii myös desimoinnin Cb:n ja Cr:n keskiarvolla, ei 2x2-lohkolle, vaan neljälle peräkkäiselle (pysty- tai vaakasuoraan) pikselille, eli 1x4-, 4x1-lohkoille ("4:1:1" -malli), sekä 2x4 ja 4x2 (kaavio "4:1:0"). Cb:lle ja Cr:lle on myös mahdollista käyttää erilaisia desimointityyppejä, mutta käytännössä tällaisia järjestelmiä käytetään erittäin harvoin.
Lisäksi kirkkauskomponentti Y ja väreistä Cb ja Cr vastaavat komponentit on jaettu 8x8 pikselin lohkoihin. Jokaiselle tällaiselle lohkolle suoritetaan diskreetti kosinimuunnos (DCT) . Tuloksena saadut DCT-kertoimet kvantisoidaan (yleensä käytetään eri kvantisointimatriiseja Y:lle, Cb:lle ja Cr:lle) ja pakataan käyttämällä run- ja Huffman-koodeja . JPEG-standardi mahdollistaa myös paljon tehokkaamman aritmeettisen koodauksen käytön, mutta käytännössä sitä käytetään harvoin patenttirajoitusten vuoksi (JPEG-standardissa kuvatun aritmeettisen QM-kooderin patentti kuuluu IBM: lle). Uusimpien versioiden suosittu libjpeg -kirjasto sisältää tuen aritmeettiselle koodaukselle, mutta tällä menetelmällä pakattujen kuvien katseleminen voi olla ongelmallista, koska monet katsojat eivät tue niiden purkamista.
DCT-kertoimien kvantisoimiseen käytetyt matriisit tallennetaan JPEG-tiedoston otsikkoon. Yleensä ne on rakennettu siten, että korkeataajuiset kertoimet altistetaan voimakkaammalle kvantisoinnille kuin matalataajuiset. Tämä johtaa kuvan hienojen yksityiskohtien karkenemiseen. Mitä suurempi pakkaussuhde, sitä vahvempi on kaikkien kertoimien kvantisointi.
Kun kuvaa tallennetaan JPEG-tiedostona, enkooderille annetaan laatuparametri jossain mielivaltaisessa yksikössä, kuten 1-100 tai 1-10. Suurempi luku tarkoittaa yleensä parempaa laatua (ja suurempaa pakattua tiedostoa). Itse JPEG-tiedostossa ei kuitenkaan ole tällaista parametria, ja rekonstruoidun kuvan laadun määräävät kvantisointimatriisit, värierokomponenttien desimointityyppi ja matemaattisten operaatioiden tarkkuus sekä enkooderin että dekooderin puolella. Tässä tapauksessa jopa korkeinta laatua käytettäessä (joka vastaa vain yksiköistä koostuvaa kvantisointimatriisia ja värierokomponenttien desimoinnin puuttumista), rekonstruoitu kuva ei täsmälleen vastaa alkuperäistä, mikä liittyy molempiin äärelliseen tarkkuuteen. DCT:stä ja tarve pyöristää Y-, Cb-, Cr- ja DCT-kertoimien arvot lähimpään kokonaislukuun. Lossless JPEG -pakkaustila, joka ei käytä DCT:tä, tarjoaa tarkan vastaavuuden palautettujen ja alkuperäisten kuvien välillä, mutta sen alhainen tehokkuus (pakkaussuhde harvoin ylittää 2) ja ohjelmistokehittäjien tuen puute eivät vaikuttaneet Losslessin suosioon. JPEG.
JPEG-standardi tarjoaa kaksi päätapaa koodatun tiedon esittämiseen.
Yleisin, jota useimmat saatavilla olevat koodekit tukevat , on peräkkäinen (peräkkäinen JPEG) dataesitys, joka sisältää koodatun kuvan peräkkäisen läpikäynnin bittisyvyydellä 8 bittiä komponenttia kohden (tai 8 bittiä pikseliä kohden mustavalkoisen harmaasävyt). kuvat) lohko lohkolta vasemmalta oikealle, ylhäältä alas. Yllä kuvatut toiminnot suoritetaan jokaiselle koodatulle kuvalohkolle, ja koodaustulokset sijoitetaan lähtövirtaan yhden "skannauksen" muodossa, toisin sanoen joukkona koodattua dataa, joka vastaa peräkkäin välitettyä ("skannattu") kuva. Perustason tai "perusviivan" koodausmoodi sallii vain tällaisen esityksen (ja kvantisoitujen DCT-kertoimien Huffman-koodauksen). Laajennettu (laajennettu) tila yhdessä peräkkäisen tilan kanssa mahdollistaa myös progressiivisen (progressiivisen JPEG) datan esittämisen, koodaamalla kuvia, joiden bittisyvyys on 12 bittiä komponenttia/pikseliä kohden (tällaisten kuvien pakkaamista JFIF-spesifikaatiolla ei tueta), ja kvantisoitujen DCT-kertoimien aritmeettinen koodaus.
Progressiivisen JPEG:n tapauksessa pakatut tiedot kirjoitetaan ulostulovirtaan skannausten sarjana, joista jokainen kuvaa koko kuvaa yhä yksityiskohtaisemmin. Tämä saavutetaan joko tallentamalla jokaisessa skannauksessa ei täydellistä sarjaa DCT-kertoimia, vaan vain osa niistä: ensin - matalataajuus, seuraavissa skannauksissa - korkea taajuus ("spektrivalinta" -menetelmä, eli spektrinäytteet ), tai peräkkäin, skannauksesta skannaukseen, DCT-kertoimien tarkentaminen ("peräkkäinen approksimaatio" -menetelmä, eli peräkkäiset approksimaatiot). Tämä tietojen progressiivinen esitys on erityisen hyödyllinen lähetettäessä pakattuja kuvia hitaiden tietoliikennekanavien avulla, koska sen avulla voit saada näkymän koko kuvasta, kun olet siirtänyt pienen osan JPEG-tiedostosta.
Molemmat kuvatut mallit (sekä peräkkäinen että progressiivinen JPEG) perustuvat DCT:hen, eivätkä ne pohjimmiltaan salli alkuperäisen kanssa täysin identtisen palautetun kuvan saamista. Standardi sallii kuitenkin myös kompression, joka ei käytä DCT:tä, vaan on rakennettu lineaarisen ennustajan (häviöttömän eli "häviöttömän", JPEG) pohjalta, mikä takaa täydellisen, bittiltä -sovituksen. alkuperäisiä ja kunnostettuja kuvia. Samanaikaisesti valokuvauskuvien pakkaussuhde saavuttaa harvoin 2, mutta vääristymien taattu puuttuminen joissakin tapauksissa on kysyntää. Huomattavasti korkeammat pakkaussuhteet voidaan saavuttaa käyttämällä ISO/IEC 14495-1:n kuvaamaa JPEG-LS- pakkausmenetelmää, joka nimien samankaltaisuudesta huolimatta ei liity suoraan JPEG ISO/IEC 10918-1 -standardiin (ITU T.81 -suositus). ) standardi (ITU T.87 suositus).
JPEG-tiedosto sisältää sarjan merkkejä , joista jokainen alkaa 0xFF-tavulla, joka osoittaa merkin alun, ja tunnistetavulla. Jotkut merkit koostuvat vain tästä tavuparista, kun taas toiset sisältävät lisädataa, joka koostuu kaksitavuisesta kentästä, jossa on merkin tietoosan pituus (mukaan lukien tämän kentän pituus, josta on vähennetty merkin alun kaksi tavua , eli 0xFF ja tunniste) ja itse tiedot. Tämän tiedostorakenteen avulla voit löytää nopeasti merkin, jossa on tarvittavat tiedot (esimerkiksi viivan pituus, rivien määrä ja pakatun kuvan värikomponenttien määrä).
Merkki | tavua | Pituus | Tarkoitus | Kommentit |
---|---|---|---|---|
NIIN MINÄ | 0xFFD8 | Ei | Kuvan aloitus | |
SOF0 | 0xFFC0 | vaihteleva koko | Kehyksen aloitus (perus, DCT) | Osoittaa, että kuva on koodattu perustilassa DCT- ja Huffman-koodilla . Merkki sisältää rivien määrän ja kuvarivin pituuden (kaksitavuiset kentät, joiden siirtymä on 5 ja 7, suhteessa merkin alkuun), komponenttien lukumäärän (tavukenttä, jonka siirtymä on 9 suhteessa merkin alkuun), bittien määrä komponenttia kohti on tiukasti 8 (tavukenttä, jonka siirtymä on 4 suhteessa alkumerkkiin), samoin kuin komponenttien suhde (esimerkiksi 4:2:0) . |
SOF1 | 0xFFC1 | vaihteleva koko | Kehyksen alku (pidennetty, DCT, Huffman-koodi) | Osoittaa, että kuva on koodattu laajennetussa tilassa DCT- ja Huffman-koodilla. Merkki sisältää kuvan rivien lukumäärän ja rivin pituuden, komponenttien lukumäärän, bittien määrän komponenttia kohden (8 tai 12) sekä komponenttien suhteen (esim. 4:2:0). |
SOF2 | 0xFFC2 | vaihteleva koko | Kehyksen alku (progressiivinen, DCT, Huffman-koodi) | Osoittaa, että kuva on koodattu progressiivisessa tilassa DCT- ja Huffman-koodilla. Merkki sisältää kuvan rivien lukumäärän ja rivin pituuden, komponenttien lukumäärän, bittien määrän komponenttia kohden (8 tai 12) sekä komponenttien suhteen (esim. 4:2:0). |
DHT | 0xFFC4 | vaihteleva koko | Sisältää Huffman-pöydät | Määrittää yhden tai useamman Huffman-taulukon. |
DQT | 0xFFDB | vaihteleva koko | Sisältää kvantisointitaulukot | Määrittää yhden tai useamman kvantisointitaulukon. |
DRI | 0xFFDD | 4 tavua | Määrittää uudelleenkäynnistysvälin pituuden | Määrittää makrolohkojen RST-merkkien n välisen etäisyyden . DRI:n puuttuessa RST-merkkien n esiintyminen koodatussa datavirrassa on laitonta ja sitä pidetään virheenä. Jos RST-markkereita n ei käytetä koodauksen aikana, DRI-merkkiä joko ei käytetä ollenkaan tai toistoväliksi siinä määritetään 0. |
SOS | 0xFFDA | vaihteleva koko | Aloita skannaus | Kuvan ensimmäisen tai seuraavan skannauksen alku ohitussuunnassa vasemmalta oikealle ylhäältä alas. Jos käytettiin peruskoodaustilaa, käytetään yhtä skannausta. Progressiivisia tiloja käytettäessä käytetään useita skannauksia. SOS-merkki erottaa kuvan informatiivisen (otsikko) ja koodatun (todellisuudessa pakatun datan) osan. |
RST n | 0xFFDn _ | Ei | uudelleenkäynnistää | Uudelleenkäynnistysmarkkereita käytetään segmentoimaan entropiakooderilla koodattua dataa. Jokaisessa segmentissä data dekoodataan itsenäisesti, mikä mahdollistaa dekoodausproseduurin rinnakkaistamisen. Jos koodatut tiedot vaurioituvat JPEG-tiedoston lähetyksen tai tallennuksen aikana, uudelleenkäynnistysmerkkien avulla voit rajoittaa häviötä (makrolohkot vahingoittumattomista segmenteistä palautetaan oikein). Lisätään joka r: nteen makrolohkoon, jossa r on merkin DRI-uudelleenaloitusväli. Ei käytetä DRI-merkin puuttuessa. n , alhainen 3 bittiä koodimerkkiä, jaksot 0 - 7. |
APP n | 0xFFen _ | vaihteleva koko | Aseta sovelluksen mukaan | Esimerkiksi JPEG-tiedoston EXIF -tiedosto käyttää APP1-merkkiä metatietojen tallentamiseen TIFF - pohjaiseen rakenteeseen . |
COM | 0xFFFE | vaihteleva koko | Kommentti | Sisältää kommentin tekstin. |
EOI | 0xFFD9 | Ei | Kuvan koodatun osan loppu. |
JPEG-pakkauksen haittoja ovat tyypillisten artefaktien esiintyminen palautetuissa kuvissa korkeilla pakkaussuhteilla : kuva on hajallaan kooltaan 8x8 pikseliä (tämä vaikutus on erityisen havaittavissa kuva-alueilla, joissa kirkkaus vaihtelee tasaisesti), alueilla, joilla on korkea. spatiaaliset taajuudet (esimerkiksi kuvan kontrastiääriviivoissa ja rajoissa) esiintyvät artefakteja kohinahalojen muodossa. JPEG-standardi (ISO/IEC 10918-1, Liite K, kohta K.8) mahdollistaa erikoissuodattimien käytön estämään lohkovirheitä, mutta käytännössä tällaisia suodattimia ei käytetä, huolimatta niiden korkeasta tehokkuudesta.
Puutteista huolimatta JPEG on kuitenkin yleistynyt melko korkean (suhteessa sen ilmestymishetkellä olemassa olleisiin vaihtoehtoihin) pakkaussuhteen, täysvärikuvien pakkaamisen tuen ja suhteellisen alhaisen laskennan monimutkaisuuden vuoksi .
JPEG-standardin mukaisen pakkausprosessin nopeuttamiseksi on perinteisesti käytetty laskelmien rinnakkaistoimintoa erityisesti DCT:tä laskettaessa. Historiallisesti yksi ensimmäisistä yrityksistä nopeuttaa pakkausprosessia tällä lähestymistavalla kuvattiin Kasperovichin ja Babkinin vuonna 1993 julkaisemassa artikkelissa [7] , jossa ehdotettiin alkuperäistä DCT-approksimaatiota, joka mahdollistaa laskelmien tehokkaan rinnakkaistamisen käyttämällä 32-bittistä yleiskäyttöä. Intel 80386 -suorittimien rekisterit . Myöhemmin ilmestyneet tehokkaammat laskentamenetelmät käyttivät x86-arkkitehtuurin prosessorin käskyjoukon SIMD -laajennuksia . Huomattavasti parempia tuloksia voidaan saavuttaa järjestelmillä, jotka käyttävät grafiikkakiihdyttimien laskentaominaisuuksia ( NVIDIA CUDA- ja AMD FireStream -tekniikat ) rinnakkaisen laskennan järjestämiseen DCT:n lisäksi myös muissa JPEG-pakkauksen vaiheissa (väriavaruuden muunnos, ajon taso, tilastollinen koodaus jne.). ) ja jokaiselle 8x8-koodatun tai dekoodatun kuvan lohkolle. Artikkelissa [8] esiteltiin JPEG-algoritmin kaikkien vaiheiden rinnakkaisuuden toteutus CUDA-tekniikalla, mikä lisäsi merkittävästi JPEG-standardin mukaista pakkaus- ja dekoodausnopeutta.
mediasäiliöt | |
---|---|
Video/ääni | |
Audio | |
Musiikki |
|
Raster | |
Vektori | |
Monimutkainen |