DWT-based compression of scientific data using CUDA. This program is tailored towards application on 3D and 4D vectorfields composed of floating point values.
This version is based on the cudaCompress fork of jebbstewart which included Linux and CMake support. The original source code belongs to m0bl0. This version included support to compress/decompress 3D/4D floating point vector fields using cudaCompress and incorporated some fixes for Windows compatability.
- C++17
- CMake 3.15+
- Git
- CUDA Toolkit
cudaVectorCompress DATASET_PATH SAVE_DECOMPRESSED SAVE_INTERLEAVED [decomposition_levels (2)] [quantization_step_size (0.00136)] [compression_iterations (10)] [huffman_bits (14)]
# Compress & save the encoded dataset, then uncompress & save decoded dataset (interleaved)
cudaVectorCompress "MyDataset.raw" 1 1
# Compress & save the encoded dataset, then uncompress & save decoded dataset (not interleaved)
cudaVectorCompress "MyDataset.raw" 1 0
# Compress & save the encoded dataset, then uncompress & save decoded dataset (not interleaved)
# Also use custom compression values (here, only the huffman bits have been increased)
cudaVectorCompress "MyDataset.raw" 1 0 2 0.00136 10 16
Parameter | Default | Meaning |
---|---|---|
DATASET_PATH |
- | Absolute path to the source dataset |
SAVE_DECOMPRESSED |
- | Whether to subsequently decode and save decoded representation |
decomposition_levels |
2 | Count of decompositions before compression |
quantization_step_size |
0.00136 | Size of the quantization steps used for compression |
compression_iterations |
10 | Count of compression iterations |
huffman_bits |
14 | Bits employed to store compressed representation |
- I get the following assertion:
Assertion failed: numRows <= 1 || rowPitch <= plan->m_rowPitches[0]
Not all dataset dimensions are equally safely supported by cudaCompress. This assertion typically only happens inDebug
mode and can be ignored by usingRelWithDebInfo
/Release
or circumvented by power-of-2-dimensions. - I get the following warning:
WARNING: distinctSymbolCount == 9225 > 1024, huffman table design failed.
In this case you should try to increase the huffman bits. If this does not work, try also other parameters, e.g., quantization step size. - How were the default values chosen?
The default values were taken from the sample implementations of the original author (Treib) and have not been changed.
Dependencies are automatically fetched via CMake and CPM.
To build, clone the project then perform the following:
cd cudaCompress
mkdir build
cd build
# Use CMAKE_CUDA_ARCHITECTURES variable suited for your hardware, 86 is suited for an RTX 3090
cmake -DCMAKE_CUDA_ARCHITECTURES=86 ..
make
You can find the correct value for DCMAKE_CUDA_ARCHITECTURES
at, e.g., https://arnon.dk.
To run the example, from the base directory (ie: cudaVectorCompress) do the following:
./build/Release/cudaVectorCompress
Holds the cudaCompressed file contents.
# myCompressedFile.cudaComp
uint: x Dim
uint: y Dim
uint: z Dim
uint: t Dim
int: number of channels
int: number of decomposition levels
float: quantization step size
int: compression iterations
int: huffman bits
for each timeslice t:
for each channel c:
uint64: count of compressed Bytes for this channel in this timeslice
*** compressed channel c for current timeslice t ***
EOF
Hold uncompressed data. If no supplementary <filename>_dims.raw
file exists, *.raw
files are expected to look like this:
# myFile.raw
uint: x Dim
uint: y Dim
uint: z Dim
uint: t Dim
*** Dataset ***
EOF
Else, if a <filename>_dims.raw
is present, they are expected to look like this:
# myFile_dims.raw
uint: x Dim
uint: y Dim
uint: z Dim
uint: t Dim
EOF
# myFile.raw
*** Dataset ***
EOF
The dataset is expected to be stored componentwise, not interleaved.
I.e., the vectors (x,y,z)
of a dataset should be saved as xxx..., yyy..., zzz...
such that the components behave like concatenated scalar 4D datasets.
This is the source code for the cudaCompress library, which was used in the papers
Interactive Editing of GigaSample Terrain Fields by Marc Treib, Florian Reichl, Stefan Auer, and Rüdiger Westermann published in Computer Graphics Forum 31,2 (Proc. Eurographics 2012) http://wwwcg.in.tum.de/research/research/publications/2012/interactive-editing-of-gigasample-terrain-fields.html
Turbulence Visualization at the Terascale on Desktop PCs by Marc Treib, Kai Bürger, Florian Reichl, Charles Meneveau, Alex Szalay, and Rüdiger Westermann published in IEEE Transactions on Computer Graphics and Visualization (Proc. IEEE Scientific Visualization 2012) http://wwwcg.in.tum.de/research/research/publications/2012/turbulence-visualization-at-the-terascale-on-desktop-pcs.html
This code is provided under the terms of the MIT license (see the file LICENSE) with the exception of the subfolders src/cudaCompress/reduce and src/cudaCompress/scan, which contain code adapted from CUDPP (http://cudpp.github.io) and come with a separate license (see file license.txt in the subfolders).
It was developed and tested on Windows 7/8 x64 with Visual Studio 2012 using CUDA 5.5. To run it, you need at least a Fermi-class GPU (NVIDIA GeForce GTX 4xx or later). If you have any questions or problems to get it running, contact me at [email protected].
If you use this code in a scientific publication, please cite the appropriate paper(s) above. If you use it for anything else, it would be nice if you could drop me a line at [email protected] and tell me about it!