The expectation of this project is to provide low level functionality for Computer Vision written in Rust to be consumed by deep learning frameworks, specially those working with images. We mainly provide I/O for images (future: video, cameras) and visualisation.
The library is written in Rust and wrapped to Python (potentially later to C/C++) using PyO3/Maturin. The library can also be used as a standalone Rust crate.
Load an image, that is converted to cv::Tensor
wich is designed centric
to the DLPack protocol to share tensor data across deep learning frameworks with a zero-copy cost.
The visualisation API is based on vviz
: https://github.com/strasdat/vviz
import kornia_rs as K
from kornia_rs import Tensor as cvTensor
cv_tensor: cvTensor = K.read_image_rs("dog.jpeg")
assert cv_tensor.shape == [195, 258, 3]
# convert to dlpack to import to torch and numpy
# NOTE: later we will support to jax and mxnet.
th_tensor = torch.utils.dlpack.from_dlpack(cv_tensor)
np_tensor = np.from_dlpack(cv_tensor)
assert th_tensor.shape == (195, 258, 3)
assert np_tensor.shape == (195, 258, 3)
- [infra] Automate packaging for manywheels.
- [kornia] integrate with the new
Image
API - [dlpack] move dlpack implementation to dlpack-rs.
- [dlpack] implement test for numpy, jax and mxnet.
- [dlpack] implement
DLPack
tocv::Tensor
. - [io] Implement image encoding and explore video.
- [viz] Fix minor issues and implement a full
VizManager
to work on the browser. - [tensor] implement basic functionality to test: add, sub, mul, etc.
- [tensor] explore xnnpack and openvino integration.
To test the project in lyour local machine use the following instructions:
- Clone the repository in your local directory
git clone https://github.com/kornia/kornia-rs.git
2.1 (optional) Build the devel.Dockerfile
Let's prepare the development environment with Docker. Make sure you have docker in your system: https://docs.docker.com/engine/install/ubuntu/
cd ./docker && ./build_devel.sh
KORNIA_RS_DEVEL_IMAGE="kornia_rs/devel:local" ./devel.sh
2.2 Enter to the devel
docker container.
./devel.sh
- Build the project
(you should now be inside the docker container)
# maturin needs you to be a `venv`
python3 -m venv .venv
source .venv/bin/activate
# build and generate linked wheels
maturin develop --extras dev
- Run the tests
pytest test/
This is a child project of Kornia. Join the community to get in touch with us, or just sponsor the project: https://opencollective.com/kornia