Skip to content

WhyS2TC

Rudolf Polzer edited this page Jul 16, 2011 · 5 revisions

Why S2TC?

S2TC is simple

S2TC's format specification is very easy to implement, so it is not hard to make a working compressor or decompressor for it.

S2TC is fast

S2TC is especially well suited for runtime (on-load) compression of textures, as it is - in low quality settings - way faster than any other texture compressors out there.

S2TC is free

S2TC is based on Color Cell Compression[1] from 1986, and decoding is done entirely using the methods from there. Encoding is done using a search and refinement method that is derived from the methods on that paper.

The compressor and decompressor here is of course licensed under a license that gives you all freedoms you will ever need (namely, the MIT license).

The Reference compressor is flexible

The S2TC reference compressor has special modes to support compressing normalmaps, and can set specific color distance metrics both for sRGB and for regular RGB. In many cases, this allows better encoding quality than the colorspace-ignorant existing S3TC compressors out there. This does not mean S2TC is better quality than S3TC - in fact, any S3TC compressor could implement these methods just as well, and get better quality out of it. However, currently no S3TC compressor supports that fully (but AMD Compressonator has some settings in that direction, which allow changing the relative color component weights, but this doesn't suffice to properly encode sRGB or normalmap textures).

References

[1]: Graham Campbell, Thomas A. DeFanti, Jeff Frederiksen, Stephen A. Joyce, and Lawrence A. Leske. 1986. Two bit/pixel full color encoding. SIGGRAPH Comput. Graph. 20, 4 (August 1986), 215-223.

Clone this wiki locally