mirror of
https://github.com/yuzu-emu/FasTC.git
synced 2025-01-22 02:41:06 +00:00
Update README.md
- Remove boost dependency and mentions - Update command line flags - Put links to different compression formats supported, and give credit where credit is due.
This commit is contained in:
parent
ab095a0a50
commit
956a5dcd9d
61
README.md
61
README.md
|
@ -1,8 +1,9 @@
|
|||
FasTC
|
||||
=======
|
||||
|
||||
A **Fas**t **T**exture **C**ompressor for the BPTC (a.k.a. BC7) format. This compressor
|
||||
supports multi-threading through Boost's threading API and runs on Windows, OS X, and Linux
|
||||
A **Fas**t **T**exture **C**ompressor for a variety of formats. This compressor
|
||||
supports multi-threading via native Win32 threads on Windows and pthreads on other
|
||||
operating systems. It has been tested on Windows, OS X, and Ubuntu Linux.
|
||||
|
||||
---
|
||||
|
||||
|
@ -10,7 +11,6 @@ Requirements:
|
|||
--------------
|
||||
|
||||
[CMake](http://www.cmake.org) (2.8.8) <br>
|
||||
[Boost](http://www.boost.org) (tested with v1.50 and higher) <br>
|
||||
[libpng](http://www.libpng.org/pub/png/libpng.html) (1.5.13) <br>
|
||||
[zlib](http://www.zlib.net) (1.2.5)
|
||||
|
||||
|
@ -33,7 +33,7 @@ Once you do this you will be able to run some examples.
|
|||
#### Using Visual Studio on Windows ####
|
||||
Due to the C/C++ runtime requirements in Visual Studio, you must have a compiled version of
|
||||
each library that you wish to link to. In order to save time, I have uploaded various versions
|
||||
of Boost, libpng, and zlib to a submodule in the source directory. Before running the steps above,
|
||||
of libpng, and zlib to a submodule in the source directory. Before running the steps above,
|
||||
make sure to instantiate the submodule in git:
|
||||
|
||||
cd FasTC/src
|
||||
|
@ -41,30 +41,57 @@ make sure to instantiate the submodule in git:
|
|||
git submodule update
|
||||
|
||||
This will download all of the Release versions of the necessary libraries (which means there will
|
||||
be linker errors during the build process). I have compiled versions for Visual Studio 2008, 2010,
|
||||
and 2012.
|
||||
be linker warnings during the build process under the Debug configuration). I have compiled
|
||||
versions for Visual Studio 2008, 2010, and 2012.
|
||||
|
||||
Testing:
|
||||
--------------
|
||||
|
||||
Once the compressor is built, you may test it against any images you wish as long as their dimensions
|
||||
are multiples of four and they are in the png file format. If you'd like to convert from one format to
|
||||
another, I suggest taking a look at [ImageMagick](http://www.imagemagick.org/script/index.php)
|
||||
are supported by the compression format and they are in the png file format. If you'd like to convert
|
||||
from one format to another, I suggest taking a look at [ImageMagick](http://www.imagemagick.org/script/index.php)
|
||||
|
||||
The quickest test will be to simply run the compressor on a PNG image:
|
||||
|
||||
cd FasTC/build
|
||||
make
|
||||
CLTool/tc path/to/image.png
|
||||
|
||||
This will compress `image.png` into the BPTC (BC7) format using 50 steps of simulated annealing without
|
||||
SIMD optimization or multithreading.
|
||||
|
||||
There are various run-time options available:
|
||||
|
||||
* `-t`: Specifies the number of threads to use for compression. The default is one.
|
||||
* `-l`: Save an output log of various statistics during compression. This is mostly only useful for debugging.
|
||||
* `-q <num>`: Use `num` steps of simulated annealing during each endpoint compression. Default is 50
|
||||
* `-v`: Enabled verbosity, which reports Entropy, Mean Local Entropy, and MSSIM in addition to
|
||||
compression time and PSNR.
|
||||
* `-f <fmt>`: Specifies the format use for compression. `fmt` can be any one of the following:
|
||||
* [BPTC](http://www.opengl.org/registry/specs/ARB/texture_compression_bptc.txt) (**Default**)
|
||||
* [ETC1](http://www.khronos.org/registry/gles/extensions/OES/OES_compressed_ETC1_RGB8_texture.txt) [1]
|
||||
* [DXT1](http://www.opengl.org/registry/specs/EXT/texture_compression_s3tc.txt) [2]
|
||||
* [DXT5](http://www.opengl.org/registry/specs/EXT/texture_compression_s3tc.txt) [2]
|
||||
* [PVRTC](http://web.onetel.net.uk/~simonnihal/assorted3d/fenney03texcomp.pdf)
|
||||
* `-t`: Specifies the number of threads to use for compression.
|
||||
* **Default**: 1
|
||||
* **Formats**: BPTC, ETC1, DXT1, DXT5
|
||||
* `-l`: Save an output log of various statistics during compression. This is mostly only useful for
|
||||
debugging.
|
||||
* **Formats**: BPTC
|
||||
* `-q <num>`: Use `num` steps of simulated annealing during each endpoint compression. Default is 50.
|
||||
Available only for BPTC.
|
||||
* **Default**: 50
|
||||
* **Formats**: BPTC
|
||||
* `-n <num>`: Perform `num` compressions in a row. This is good for testing metrics.
|
||||
* `-a`: Use a parallel algorithm that uses Fetch-And-Add and Test-And-Set to perform mutual exclusion and avoid synchronization primitives. This algorithm is very useful when compressing a list of textures. Cannot be used with the `-j` option.
|
||||
* `-j <num>`: This specifies the number of 4x4 blocks that the compressor will crunch per thread. The default is to split the image up so that each thread compresses an equal share of the image. However, for many images, certain blocks compress faster than others, and you might want a more fine grained control over how to switch between compressing different blocks.
|
||||
* **Default**: 1
|
||||
* **Formats**: All
|
||||
* `-a`: Use a parallel algorithm that uses Fetch-And-Add and Test-And-Set to perform mutual exclusion
|
||||
and avoid synchronization primitives. This algorithm is very useful when compressing a list of textures.
|
||||
Cannot be used with the `-j` option.
|
||||
* **Formats**: BPTC
|
||||
* `-j <num>`: This specifies the number of blocks that the compressor will request to crunch per thread. If this
|
||||
flag is not specified or set to zero, the image will be split up so that each thread compresses an
|
||||
equal share. However, for many images, certain blocks compress faster than others, and you might want
|
||||
a more fine grained control over how to switch between compressing different blocks.
|
||||
* **Formats**: BPTC, ETC1, DXT1, DXT5
|
||||
|
||||
As an example, if I wanted to test compressing a texture using no simulated annealing, 4 threads, and 32 blocks per job,
|
||||
I would invoke the following command:
|
||||
|
@ -76,3 +103,11 @@ with atomic synchronization primitives, I would invoke the following command:
|
|||
|
||||
CLTool/tc -n 100 -a path/to/image.png
|
||||
|
||||
|
||||
If I wanted to compress a texture into PVRTC, I would invoke the following command:
|
||||
|
||||
CLTool/tc -f PVRTC path/to/image.png
|
||||
|
||||
[1] Compression code courtesy of [Rich Geldreich](https://code.google.com/p/rg-etc1/) <br>
|
||||
[2] Compression code courtesy of [Intel](http://software.intel.com/en-us/vcsource/samples/fast-texture-compression).
|
||||
The idea implemented in this compressor was originally designed by [J. M. P. Van Waveren](http://www.gamedev.no/projects/MegatextureCompression/324337_324337.pdf)
|
||||
|
|
Loading…
Reference in a new issue