Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/fhanau/Efficient-Compression-Tool
Fast and effective C++ file optimizer
https://github.com/fhanau/Efficient-Compression-Tool
Last synced: 3 months ago
JSON representation
Fast and effective C++ file optimizer
- Host: GitHub
- URL: https://github.com/fhanau/Efficient-Compression-Tool
- Owner: fhanau
- License: apache-2.0
- Created: 2015-04-30T22:25:36.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2024-04-06T08:45:35.000Z (10 months ago)
- Last Synced: 2024-08-01T02:24:09.972Z (6 months ago)
- Language: C
- Homepage:
- Size: 4.74 MB
- Stars: 561
- Watchers: 27
- Forks: 40
- Open Issues: 23
-
Metadata Files:
- Readme: README.md
- License: License.txt
Awesome Lists containing this project
- awesome-compopt - ECT - Fast and effective C++ file optimizer (Image / Availability & compatability)
README
Efficient Compression Tool
============================Efficient Compression Tool (or ECT) is a C++ file optimizer.
It supports PNG, JPEG, GZIP and ZIP files.Performance (v0.9.2)
-------------------------
All tests were run on macOS 12.5 using an Intel i7-7700HQ and clang.
File: enwik8, 100,000,000 bytes, compressed into gzip format| Compressor | File Size | Time |
| ---------- | ----- | ---------- |
| ECT -1 | 36,493,257 | 3.5s |
| gzip -9 | 36,475,811 | 5.8s |
| [zopfli] -i1 | 35,102,371 | 1m 30.2s |
| ECT -2 | 35,019,440 | 14.8s |
| zopfli -i5 | 34,983,757 | 2m 12.0s |
| ECT -3 | 35,014,543 | 16.2s |
| zopfli -i15 | 34,966,078 | 3m 59.9s |
| ECT -4 | 34,963,581 | 19.8s |
| zopfli -i30 | 34,961,453 | 6m 30.6s |
| ECT -5 | 34,942,796 | 25.1s |
| ECT -6 | 34,943,943 | 41.9s |
| ECT -7 | 34,942,348 | 59.7s |
| ECT -8 | 34,941,125 | 2m 25.6s |
| ECT -9 | 34,937,781 | 3m 17.9s |[zopfli]: https://github.com/google/zopfli
## Building
To build ECT, you need to recursively clone it, just downloading isn’t enough, i. e. `git clone --recursive https://github.com/fhanau/Efficient-Compression-Tool.git`
You may also need to install `nasm` if it is not available already.### Command line
ECT is built with `cmake`
```bash
mkdir build
cd build
cmake ../src
make
```In addition, you can add the following arguments to the cmake call to turn various features on and off:
- `-DECT_MULTITHREADING=OFF`: Turn off multithreading support### With Xcode
You can use cmake to generate an Xcode project. Just add `-G Xcode` to the end of the cmake command:
```bash
mkdir build
cd build
cmake ../src -G Xcode
make
```
You will run into a slight issue in that Xcode doesn't know how to compile some of the asm files within mozjpeg. To fix this, locate your copy of `nasm` (`/usr/local/bin/nasm` in the example) navigate to the Build Rules of the `simd` target, and add a custom rule to process source files matching `*.asm` with the following script:
```sh
/usr/local/bin/nasm "-I${PROJECT_DIR}/mozjpeg" -DMACHO -D__x86_64__ "-I${PROJECT_DIR}/mozjpeg/simd/nasm/" "-I${PROJECT_DIR}/mozjpeg/simd/x86_64/" -f macho64 -o "${BUILT_PRODUCTS_DIR}/x86_64/${INPUT_FILE_BASE}.o" "${INPUT_FILE_PATH}"
```
and set `$(BUILT_PRODUCTS_DIR)/x86_64/${INPUT_FILE_BASE}.o` as the output files.If you are using Xcode for development and do not need maximum speed, you can also disable the asm files by adding `-DWITH_SIMD=OFF` to the cmake.