WARNIG! This is still experimental project and WORK IN PROGRESS project!! not working yet
TinyVDBIO is header-only C++11 OpenVDB IO library. Not all OpenVDB format are supported. Also, TinyVDBIO does not provide non-IO related features(e.g. volume op, iso-surface generation).
TinyVDBIO is good for not only your graphics application, but also HPC visualization tools.
- [x] Dependency-free C++11 code.
- [x] Big endian support(e.g. Power, SPARC)
- [x] Cross-platform(should be at least compilable on Linux, macOS and Windows)
- [x] Limited support of loading OpenVDB data(version from 220 to 223 are supported)
- [x] ZIP compression
- [x] BLOSC compression
- [ ] Simple saving of OpenVDB data.
- [ ] Support big endian machine(e.g. SPARC, POWER).
- Will be supported soon!
File version less than 220(OPENVDB_FILE_VERSION_SELECTIVE_COMPRESSION
) is not supported.
Currently, only FloatTree
(tree::Tree4<float, 5, 4, 3>::Type
) topology is supported.
(At least example VDB files at http://www.openvdb.org/download/ could be read in TinyVDB)
- [ ] Multi-threaded decoding using C++11 thread.
- [ ] Support points.
- [ ] Support various topology type.
- [ ] Support Multipass IO version(224)
- [ ] mmap based accesss for larger data set.
- [ ] Switch to MIT license by removing OpenVDB code(MPL 2.0 licensed code)
Simply copy src/tinyvdbio.h
and src/miniz.c
and src/miniz.h
to your project.
Recent OpenVDB file(223~) are usually compressed using BLOSC, so it is highly recommended to enable BLOSC suppor(see the below for compiliation).
- TINYVDBIO_USE_BLOSC : Enable Blosc compression.
- TINYVDBIO_USE_SYSTEM_ZLIB : TinyVDBIO use
miniz
as a default zip compression library. You can define thisTINYVDBIO_USE_SYSTEM_ZLIB
to use system provided zlib library. Plese add an include path tozlib.h
if required.
// Uncomment this if you want to use system provided zlib library.
// #define TINYVDBIO_USE_SYSTEM_ZLIB
// #include <zlib.h>
// define this only in *one* .cc file.
#define TINYVDBIO_IMPLEMENTATION
#include "tinyvdbio.h"
T.B.W.
TODO: Convert OpenVDB data to NanoVDB usint TinyVDBIO
$ git submodule update --init --recursive --depth 1
$ cd third_party/c-blosc/
$ rm -rf build
$ mkdir build
$ cd build
$ cmake ..
$ make
CMake build is provided for example/test build.
$ mkdir build
$ cd build
$ cmake ..
$ make
- TINYVDBIO_USE_BLOSC : Enable Blosc compression. In cmake build, blosc is built with
add_subdirectory
- TINYVDBIO_USE_SYSTEM_ZLIB : Use system zlib.
- Optinally you can specify path to zlib with
ZLIB_ROOT
https://cmake.org/cmake/help/latest/module/FindZLIB.html
- Optinally you can specify path to zlib with
background
is a uniform constant value used when there is no voxel data.
Node
is composed of Root, Internal and Leaf.
Leaf contains actual voxel data.
Root and Internal node have Value
or pointer to child node, where Value
is a constant value for the node(i.e. 1x1x1 voxel data).
There are two bit masks, child mask
and value mask
, for each Node
.
TinyVDBIO is released under the Mozilla Public License Version 2.0, which is a free, open source, and detailed software license developed and maintained by the Mozilla Foundation. It is a hybrid of the modified BSD license and the GNU General Public License (GPL) that seeks to balance the concerns of proprietary and open source developers.
- imgui : MIT license
- stb series : Public domain
- glfw3 : zlib license
- glad : ???
- clipp: MIT license.
- nanovdb : MPL 2.0 license.
TinyVDB uses some code from OpenVDB related to IO, Archive and Tree. According to MPL2.0, Modifing source code may loose patent grant from original contributors(in this case, DreamWorks).
At this point, it looks there is no claimed patent(including application or pending phase) for hierarchical grid representation by DreamWorks.