1. Computers
  2. Display Drivers
  3. Graphics Cards
  4. Memory
  5. Motherboards
  6. Processors
  7. Software
  8. Storage
  9. Operating Systems


Facebook RSS Twitter Twitter Google Plus


Phoronix Test Suite

OpenBenchmarking.org

ETC2 Texture Compression Looks Good For OpenGL

Mesa

Published on 12 August 2012 03:56 PM EDT
Written by Michael Larabel in Mesa
26 Comments

With OpenGL ES 3.0 and OpenGL 4.3 there is now mandatory texture compression support in the form of ETC2, the Ericsson Texture Compression method.

The slides pertaining to the mandated ETC2 support in the latest GL standards from SIGGRAPH 2012 have now been uploaded. ETC1/ETC2 was designed by Ericsson Research and this means of texture compression is quite interesting. ETC2 also isn't covered by patents like the notorious for open-source but widely-used S3TC texture compression.

This past week the Khronos Group also unveiled ASTC as a means of next-generation royalty-free texture compression. The Adaptive Scalable Texture Compression (ASTC) though isn't yet mandated by the latest OpenGL specification.

ETC2 Texture Compression Looks Good For OpenGL ETC2 Texture Compression Looks Good For OpenGL ETC2 Texture Compression Looks Good For OpenGL

ETC2 is higher quality than its predecessor and also introduces support for alpha pixels and R-/RG- textures. As mentioned already, ETC2 texture compression support is mandatory with OpenGL 4.3 and OpenGL ES 3.0. Graphics texture compression reduces memory usage and avoids congesting the bus, thereby trying to avoid a performance bottleneck.

ETC2 Texture Compression Looks Good For OpenGL ETC2 Texture Compression Looks Good For OpenGL ETC2 Texture Compression Looks Good For OpenGL

ETC2 and other means of texture compression allows for more textures to fit in video memory, leads to less traffic on the bus for higher performance and lower power consumption, and it becomes cheaper to transit textures over networks. ETC1 has been available for years and has shipped in Google's Android since 2.2-Froyo, but until this week was not mandated as part of the OpenGL ES specification. ETC1 had limitations of not supporting alpha and RG-textures, but that's been addressed by this latest version. ETC2 is the same bit-rate as ETC1 but with enhanced quality. Ericsson Research states that ETC2 is about 1.0 dB better than ETC1, 0.8 dB better than S3TC/DXTC, and 1.6 dB better than PVR-TC texture compression. The Khronos ASTC texture compression is slightly better than ETC2.

ETC2 Texture Compression Looks Good For OpenGL ETC2 Texture Compression Looks Good For OpenGL ETC2 Texture Compression Looks Good For OpenGL

Here's some sample images of the original source, S3TC, ETC1, and ETC2. ETC2 definitely delivers superior quality to ETC1 and is comparable to S3 Texture Compression.

ETC2 Texture Compression Looks Good For OpenGL ETC2 Texture Compression Looks Good For OpenGL ETC2 Texture Compression Looks Good For OpenGL

ETC2 is backwards compatible with ETC1.

ETC2 Texture Compression Looks Good For OpenGL ETC2 Texture Compression Looks Good For OpenGL ETC2 Texture Compression Looks Good For OpenGL

Ericsson has made available a compression for handling ETC1/ETC2/EAC.

ETC2 Texture Compression Looks Good For OpenGL ETC2 Texture Compression Looks Good For OpenGL ETC2 Texture Compression Looks Good For OpenGL

Compared to the new Khronos ASTC texture compression method, ETC2/EAC codecs are now mandatory with the GL/GLES specifications while ASTC is optional for now, ETC2 is backwards compatible with ETC1, implemented in silicon ETC2 is likely smaller than ASTC, and ETC2 has punch-through alpha support. To the advantage of ASTC there is support for more bit rates (ETC2 is limited to 4 bits per pixel) and ASTC has slightly higher quality (about half a dB compared to ETC2).

About The Author
Michael Larabel is the principal author of Phoronix.com and founded the web-site in 2004 with a focus on enriching the Linux hardware experience and being the largest web-site devoted to Linux hardware reviews, particularly for products relevant to Linux gamers and enthusiasts but also commonly reviewing servers/workstations and embedded Linux devices. Michael has written more than 10,000 articles covering the state of Linux hardware support, Linux performance, graphics hardware drivers, and other topics. Michael is also the lead developer of the Phoronix Test Suite, Phoromatic, and OpenBenchmarking.org automated testing software. He can be followed via and or contacted via .
Latest Linux Hardware Reviews
  1. Intel Xeon E5-1680 v3 & E5-2687W v3 Compared To The Core i7 5960X On Linux
  2. Intel 120GB 530 Series SSD Linux Performance
  3. Btrfs/EXT4/XFS/F2FS RAID 0/1/5/6/10 Linux Benchmarks On Four SSDs
  4. AMD's Windows Catalyst Driver Remains Largely Faster Than Linux Drivers
Latest Linux Articles
  1. NVIDIA vs. Nouveau Drivers With Linux 3.18 + Mesa 10.4-devel
  2. Is The Open-Source NVIDIA Driver Fast Enough For Steam On Linux Gaming?
  3. Linux 3.18 File-System Performance Minimally Changed But Possible Regressions
  4. AMD Radeon Gallium3D Is Catching Up & Sometimes Beating Catalyst On Linux
Latest Linux News
  1. There's New In-Fighting Over The Future Of Compiz
  2. GTK+ Inspector Gains More Features Ahead Of GNOME 3.16
  3. Clang 3.6 Will Hopefully Have OpenMP Support
  4. A Go Front-End Could Soon Be Landing In LLVM
  5. Linux 3.18-rc6 Released, A Worrisome Regression Remains
  6. HandBrake 0.10 Brings H.265 & VP8 Encoders
  7. Gngr: A New Web Browser Focused On Privacy
  8. Linux 3.18 Kernel: Not Much Change With Intel Haswell Performance
  9. More File-System Tests Of The Linux 3.18 Kernel
  10. Using NVIDIA's NVENC On Linux With FFmpeg
Latest Forum Discussions
  1. how to configure module phoromatic ?
  2. PulseAudio 6.0 Is Coming & Other Linux Audio Plans For The Future
  3. Debian Developer Resigns From The Systemd Maintainership Team
  4. Roadmap to Catalyst 14.10 ?
  5. Updated and Optimized Ubuntu Free Graphics Drivers
  6. Cant get working Kaveri APU - A10-7850k
  7. Script for Fan Speed Control
  8. Debian Init System Coupling Vote Results