Jádro (zpracování obrazu) - Kernel (image processing)
v zpracování obrazu, a jádro, konvoluční maticenebo maska je malý matice. Používá se k rozmazání, ostření, embosování, Detekce hrany, a více. Toho je dosaženo provedením a konvoluce mezi jádrem a obraz.
Detaily
Obecný výraz konvoluce je
kde je filtrovaný obrázek, je původní obrázek, je jádro filtru. Každý prvek jádra filtru je považován za a .
V závislosti na hodnotách prvku může jádro způsobit širokou škálu efektů.
Úkon | Jádro ω | Výsledek obrázku g (x, y) |
---|---|---|
Identita | ||
Detekce hrany | ||
Zaostřit | ||
Rozostření pole (normalizováno ) | ||
Gaussovské rozostření 3 × 3 (přiblížení) | ||
Gaussovské rozostření 5 × 5 (přiblížení) | ||
Neostré maskování 5 × 5 Na základě Gaussova rozostření s částkou 1 a prahová hodnota jako 0 (s č obrazová maska ) |
Výše uvedené je jen několik příkladů efektů dosažitelných spojením jader a obrázků.
Původ
Počátek je poloha jádra, která je nad (koncepčně) aktuálním výstupním pixelem. To by mohlo být mimo skutečné jádro, i když obvykle to odpovídá jednomu z prvků jádra. U symetrického jádra je počátek obvykle středovým prvkem.
Konvoluce
Konvoluce je proces přidání každého prvku obrazu k jeho místním sousedům, váženého jádrem. To souvisí s formou matematická konvoluce. Maticová operace provádění - konvoluce - není tradiční násobení matic, přestože je podobně označeno *.
Například pokud máme dvě matice tři ku třem, první jádro a druhou část obrazu, konvoluce je proces převrácení řádků i sloupců jádra a vynásobení lokálně podobných položek a sčítání. Prvek na souřadnicích [2, 2] (tj. Centrální prvek) výsledného obrázku by byl váženou kombinací všech položek matice obrazu s váhami danými jádrem:
Ostatní položky by byly podobně vážené, kde bychom umístili střed jádra na každý z hraničních bodů obrazu a vypočítali vážený součet.
Hodnoty daného pixelu ve výstupním obrazu se vypočítají vynásobením každé hodnoty jádra odpovídajícími hodnotami pixelu vstupního obrazu. To lze popsat algoritmicky pomocí následujícího pseudokódu:
pro každého řádek obrázku v vstupní obrázek: pro každého pixel v řádek obrázku: soubor akumulátor na nulu pro každého řádek jádra v jádro: pro každého živel v řádek jádra: -li pozice prvku souhlasí s poloha pixelu pak násobit hodnota prvku souhlasí s hodnota pixelu přidat výsledek na akumulátor endif soubor výstupní obrazový pixel na akumulátor
- * Odpovídající pixely vstupního obrazu se nacházejí relativně k původu jádra.
Pokud je jádro symetrické, umístěte střed (počátek) jádra na aktuální pixel. Jádro překrývá sousední pixely kolem počátku. Každý prvek jádra by měl být vynásoben hodnotou pixelu, s níž se překrývá, a všechny získané hodnoty by měly být sečteny. Tento výsledný součet bude novou hodnotou pro aktuální pixel, který se aktuálně překrývá se středem jádra.
Pokud jádro není symetrické, musí být před výpočtem konvoluce, jak je uvedeno výše, otočeno jak kolem jeho vodorovné, tak i svislé osy.[1]
Obecná forma konvoluce matice je
Zpracování hran
Konvoluce jádra obvykle vyžaduje hodnoty z pixelů mimo hranice obrazu. Existuje řada metod pro manipulaci s okraji obrazu.
- Rozšířit
- Nejbližší okrajové pixely jsou koncepčně rozšířeny, pokud je to nutné, aby poskytly hodnoty pro konvoluci. Rohové pixely jsou prodlouženy v 90 ° klínech. Ostatní okrajové pixely jsou rozšířeny v řádcích.
- Zabalit
- Obrázek je koncepčně zabalen (nebo obložen) a hodnoty jsou převzaty z opačného okraje nebo rohu.
- Zrcadlo
- Obraz je koncepčně zrcadlen na okrajích. Například pokus o načtení pixelu 3 jednotky mimo hranu přečte místo toho 3 jednotky uvnitř hrany.
- Oříznutí
- Jakýkoli pixel ve výstupním obrazu, který by vyžadoval hodnoty za hranu, je přeskočen. Tato metoda může vést k tomu, že výstupní obraz bude o něco menší a okraje budou oříznuty.
- Oříznutí jádra
- Žádný pixel v jádře, který přesahuje vstupní obrázek, se nepoužívá a normalizace se upraví tak, aby kompenzovala.
Normalizace
Normalizace je definována jako rozdělení každého prvku v jádře součtem všech prvků jádra, takže součet prvků normalizovaného jádra je jednota. Tím zajistíte, že průměrný pixel v upraveném obrázku bude stejně jasný jako průměrný pixel v původním obrázku.
Konkrétní realizace
Zde je konkrétní implementace konvoluce provedená pomocí GLSL stínovací jazyk:
// autor: csblo// Práce vytvořená pouze konzultací:// https://en.wikipedia.org/wiki/Kernel_(image_processing)// Definujte jádra#define identity mat3 (0, 0, 0, 0, 1, 0, 0, 0, 0)#define edge0 mat3 (1, 0, -1, 0, 0, 0, -1, 0, 1)#define edge1 mat3 (0, 1, 0, 1, -4, 1, 0, 1, 0)#define edge2 mat3 (-1, -1, -1, -1, 8, -1, -1, -1, -1)#define zostřit mat3 (0, -1, 0, -1, 5, -1, 0, -1, 0)#define box_blur mat3 (1, 1, 1, 1, 1, 1, 1, 1, 1) * 0,1111#define gaussian_blur mat3 (1, 2, 1, 2, 4, 2, 1, 2, 1) * 0,0625#define emboss mat3 (-2, -1, 0, -1, 1, 1, 0, 1, 2)// Najít souřadnice maticového prvku z indexuvec2 kpos(int index){ vrátit se vec2[9] ( vec2(-1, -1), vec2(0, -1), vec2(1, -1), vec2(-1, 0), vec2(0, 0), vec2(1, 0), vec2(-1, 1), vec2(0, 1), vec2(1, 1) )[index] / iResolution.xy;}// Extrahujte oblast dimenze 3x3 ze vzorkovače se středem v uv// sampler: sampler textury// uv: aktuální souřadnice na vzorníku// návrat: pole mat3, každý index odpovídá barevnému kanálumat3[3] region3x3(sampler2D vzorkovač, vec2 uv){ // Vytvořte každý pixel pro region vec4[9] kraj; pro (int i = 0; i < 9; i++) kraj[i] = textura(vzorkovač, uv + kpos(i)); // Vytvořte region 3x3 se 3 barevnými kanály (červený, zelený, modrý) mat3[3] mRegion; pro (int i = 0; i < 3; i++) mRegion[i] = mat3( kraj[0][i], kraj[1][i], kraj[2][i], kraj[3][i], kraj[4][i], kraj[5][i], kraj[6][i], kraj[7][i], kraj[8][i] ); vrátit se mRegion;}// Spojte texturu s jádrem// kernel: jádro použité pro konvoluci// sampler: sampler textury// uv: aktuální souřadnice na vzorníkuvec3 konvoluce(mat3 jádro, sampler2D vzorkovač, vec2 uv){ vec3 fragment; // Extrahujte oblast 3x3 se středem v uv mat3[3] kraj = region3x3(vzorkovač, uv); // pro každý barevný kanál regionu pro (int i = 0; i < 3; i++) { // získat kanál regionu mat3 rc = kraj[i]; // násobení komponent jádrem podle regionálního kanálu mat3 C = matrixCompMult(jádro, rc); // přidat každou složku matice plovák r = C[0][0] + C[1][0] + C[2][0] + C[0][1] + C[1][1] + C[2][1] + C[0][2] + C[1][2] + C[2][2]; // pro fragment na kanálu i, nastavte výsledek fragment[i] = r; } vrátit se fragment; }prázdnota mainImage( ven vec4 fragColor, v vec2 fragCoord ){ // Normalizované souřadnice pixelů (od 0 do 1) vec2 uv = fragCoord/iResolution.xy; // Spojte jádro s texturou vec3 plk = konvoluce(vytepat, iChannel0, uv); // Výstup na obrazovku fragColor = vec4(plk, 1.0);}
Reference
- Ludwig, Jamie (n.d.). Konvoluce obrazu (PDF). Státní univerzita v Portlandu.
- Lecarme, Olivier; Delvare, Karine (leden 2013). Kniha GIMP: Kompletní průvodce téměř vším. Žádný lis na škrob. str. 429. ISBN 978-1593273835.
- Gumster, Jason van; Shimonski, Robert (březen 2012). Bible GIMP. Wiley. 438–442. ISBN 978-0470523971.
- Shapiro, Linda G.; Stockman, George C. (únor 2001). Počítačové vidění. Prentice Hall. str. 53–54. ISBN 978-0130307965.