View on GitHub

OpenJPH

Open-source implementation of JPEG2000 Part-15 (or JPH or HTJ2K)

Compiling

The code employs the cmake tool to generate a variety of build environments. A visual studio code container is included for building using the visual studio code remote containers add in (highly recommended)

For Linux

You may need to install libtiff; then,

cd build
cmake -DCMAKE_BUILD_TYPE=Release  ../
make 
sudo make install

For Windows

Compilation depends on libtiff. A pre-compiled library with all the library features for Windows is not available; I am using this, but I think I have only the basic library.

cd build
cmake .. -G "Visual Studio 17 2022 Win64" -DCMAKE_PREFIX_PATH=<tiff library path>

cmake supports other visual studio versions. This command generates a solution in the build folder, which can be build using visual studio.

To compile from the command line, use

cmake --build . --config Release

To install either use

cmake --install . --prefix <your folder>

to install the library to your desired folder, or, if you want to install to C:\Program Files, you need a PowerShell/CMD running as administrator, and

cmake --install .

For macOS

You can use the “For Linux” approach above. Alternatively, you can use the Xcode project in src/apps/apps.xcodeproj, which I use. Another approach is to use cmake to generate an xcode project, in the build folder, using

cd build
cmake ../ -G Xcode
make
sudo make install

I have not tested this in a long time, but you get the picture.

Building Tests

When you invoke cmake add -DOJPH_BUILD_TESTS=ON, then, for Windows

cd tests
ctest -C Release

For other platforms

cd tests
ctest

The test setup is a bit finicky, and may sometimes fail for silly reasons.

Compiling to Node.js

The library can be compiled to run with Node.js. Compilation needs the emscripten tools. One way of using these tools is to install them on your machine, and activate them using, assuming running on platform other than Windows,

source emsdk_env.sh

before compilation. Then, emcmake cmake .. emmake make

Compilation will generate two version of the library and executables, one with WebAssembly SIMD instructions and one without.

Compiling to javascript/wasm

The library can now be compiled to javascript/wasm. For this purpose, a small wrapper file (ojph_wrapper.cpp) has been written to interface between javascript and C++; the wrapper currently supports decoding only. A small demo page demonstrating the script can be accessed here.

Compilation needs the emscripten tools. One way of using these tools is to install them on your machine, and activate them using

source emsdk_env.sh

before compilation. Alternatively, if you are a docker user, the you can launch a docker session using script provided at subprojects/js/emscripten-docker.sh; this script will download a third-party docker image that has the emscripten tools integrated in it – Thanks to Chris for the suggesting and providing these tools.

The javascript decoder can be compiled using

cd subprojects/js/build
emcmake cmake ..
emmake make

The compilation creates libopenjph.js and libopenjph.wasm in subprojects/js/html folder; it also creates libopenjphsimd.js and libopenjphsimd.wasm. That html folder also has the demo webpage index.html and a compressed image test.j2c which the script in index.html decodes. The index.html detects if the browser supports WebAssembly SIMD instructions, and loads the correct library accordingly.

To run the demo webpage on your machine, you need a webserver running on the machine – Due to security reasons, javascript engines running in a browser cannot access local files on the machine. You can use the emrun command, provided with the emscripten tools, by issuing the command

emrun index.html

from inside the html folder; the default port is 6931. Alternatively, a simple python webserver can be run using

python -m http.server 8000

also from inside the html folder. Here, 8000 is the port number at which the webserver will be listening. The webpage can then be accessed by open localhost:8000 in you browser. Any browser supporting webassembly can be used to view this webpage; examples include Firefox, Chrome, Safari, and Edge, on a desktop, mobile, or tablet.

Visual Studio Code Remote Containers

Visual Studio Code Remote Containers are now available with OpenJPH. These scripts/configuration files are provided by Chris – Thank you Chris, and I must say I am not familiar with them. The scripts, in the .devcontainer folder, will build a docker image that can be used with visual studio code as a development environment.

Compiling for ARM and other platforms

Compilation should simply work now. The simple test code I have passes when run on MacOS ARM on GitHub.

Disabling SIMD instructions

The code now employs the architecture-agnostic option OJPH_DISABLE_SIMD, which should include SIMD instructions wherever they are supported. This can be achieved with -DOJPH_DISABLE_SIMD=ON option during CMake configuration. Individual instruction sets can be disabled; see the options in the main CMakeLists.txt file.