Custom Camera Calibrations
Note
This feature is new in version 1.8.0 of kognic-io and some parts require optional dependencies. Run pip install kognic-io[wasm] to install it.
If your calibration is not in the list of supported standard camera calibrations, you can provide a custom calibration. The table below show the attributes of the CustomCameraCalibration object. The wasm_base64 attribute is a base64 encoded string of the WebAssembly module that implements the calibration. The test_cases attribute is a list of TestCase objects that are used to validate the calibration during creation. It is recommended to provide a few test cases to make sure that the calibration is correct.
Key | Value | Parameters |
---|---|---|
rotation_quaternion | A RotationQuaternion object | w, x, y, z |
position | A Position object | x, y, z |
image_width | Integer | NA |
image_height | Integer | NA |
wasm_base64 | String | NA |
test_cases | A list of TestCase objects | point3d, point2d |
The CustomCameraCalibration object can conveniently be instantiated directly from the binary or a wasm-file:
We provide a set of utilities that will make it easier to work with the WebAssembly module. More specifically we provide validation code and compilation code from a few different languages to WebAssembly. The code is available both as python functions and via the kognicutil cli.
The WebAssembly must follow a strict interface where the module exports a function called project_point_to_image. The function must take three arguments of type float64 and return two values of type float64. Thus, the WebAssembly text representation of this interface is func (param f64 f64 f64) (result f64 f64). The three arguments are the x, y and z coordinates of the 3D point. The two return values are the x and y coordinates of the projected point in the image plane. WebAssembly doesn't support multiple return values by default but this can be enabled with the multi-value proposal.
If the point is not within the field of view, the function should return NaN for both the x and y coordinates.
Note
This requires wasmtime to be installed which is an optional of dependency kognic-io. Run pip install kognic-io[wasm] to install it.
We provide validation code both as python functions and via the kognicutil cli. We validate things such as but not limited to
- The module can be loaded
- The function exists and has the correct signature
- That a point can be projected using the module
- That points are projected correctly if test cases are provided
In python there are three different ways to validate a calibration
The kognicutil cli can be used as follows
Caution
Rust 1.82.0 removes support for the multivalue feature target (returning multiple values from a function). Since this feature is currently needed for custom camera calibrations to work, the Rust and/or Cargo version needs to be pinned to < 1.82.0.
Note
It is recommended to keep the wasm file as small as possible. Try to avoid dependencies that are not needed. For example, it may be preferred to implement some mathematical functions yourself instead of using the standard library.
As stated above the WebAssembly module must follow a strict interface and compilation requires the multi-value proposal. We provide a set of utilities that will make it easier to compile the WebAssembly module from a few languages, see table below.
Language | Target | Compilation tool | Required version |
---|---|---|---|
Rust | *.rs | rustc | < 1.82.0 |
Rust (Cargo) | Cargo.toml | cargo | < 1.82.0 |
C++ | *.cc, *.cpp | emscripten | N/A |
C | *.c | emscripten | N/A |
The utilities are available both as python functions and via the kognicutil cli. From Python, you can compile the module with
The returned binary can then be used to create a CustomCameraCalibration object. If the output_wasm parameter is passed, the binary will be saved to the specified path. The kognicutil cli can be used as follows
Note that, validation is run by default after compilation. This can be disabled with the --skip-validation flag.
Calibration parameters have to be embedded in the binary so that they can be used by the WebAssembly module. Try to pre-compute as much as possible to increase the speed of the projection function at runtime.
Below follows examples of a simplified version of the pinhole calibration in a few different languages.
Note
Rust needs to be installed with the wasm32-wasi target for this. Install Rust according to the instructions here and then add the target with rustup target add wasm32-wasi.
A Rust file can be compiled with
Note that panics are not supported and compilation will fail if the code contains it.
Note
Rust and Cargo need to be installed with the wasm32-wasi target for this. Install Rust and Cargo according to the instructions here and then add the target with rustup target add wasm32-wasi.
A Rust module with Cargo can be compiled with
Note that it is important to specify that the library is a cdylib and it is also recommended to set strip = true to reduce the size of the WebAssembly module. This is done by adding the following to the Cargo.toml file
Note
Emscripten needs to be installed for this, which can be done according to the instructions here.
A C++ file can be compiled with
or with
Note
Emscripten needs to be installed for this, which can be done according to the instructions here.
A C file can be compiled with