This project provides all the basics to use the Khiops Native Interface (KNI): installation and examples.
The purpose of KNI is to allow a deeper integration of Khiops in information systems, by mean of the C programming language, using a shared library (.dll
in Windows, .so
in Linux). This relates specially to the problem of model deployment, which otherwise requires the use of input and output data files when using directly the Khiops tool in batch mode. See Khiops Guide for an introduction to dictionary files, dictionaries, database files and deployment.
The Khiops deployment API is thus made public through a shared library. Therefore, a Khiops model can be deployed directly from any programming language, such as C, C++, Java, Python, Matlab, etc. This enables real time model deployment without the overhead of temporary data files or launching executables. This is critical for certain applications, such as marketing or targeted advertising on the web..
All KNI functions are C functions for easy use with other programming languages. They return a positive or zero value in case of success, and a negative error code in case of failure.
See KhiopsNativeInterface.h for a detailed description of KNI functions.
Caution
The functions are not reentrant (thread-safe): the library can be used simultaneously by several executables, but not simultaneously by several threads in the same executable.
Download KNI-10.2.4.zip and extract it to your machine. Set the environment variable KNI_HOME
to the extracted directory. This variable is used in the following examples.
On Linux, go to the release page and download the KNI package. The name of the package begins with kni and ends with the code name of the OS. The code name is in the release file of the distribution (here, it is "jammy"):
$ cat /etc/os-release
PRETTY_NAME="Ubuntu 22.04.4 LTS"
NAME="Ubuntu"
VERSION_ID="22.04"
VERSION="22.04.4 LTS (Jammy Jellyfish)"
VERSION_CODENAME=jammy
ID=ubuntu
ID_LIKE=debian
HOME_URL="https://www.ubuntu.com/"
SUPPORT_URL="https://help.ubuntu.com/"
BUG_REPORT_URL="https://bugs.launchpad.net/ubuntu/"
PRIVACY_POLICY_URL="https://www.ubuntu.com/legal/terms-and-policies/privacy-policy"
UBUNTU_CODENAME=jammy
Download the package according to the code name of your OS and install it with dpkg
or yum
:
- on Debian-like distros:
sudo dpkg -i kni*.deb
- on Fedora-like distros:
sudo yum localinstall kni*.rpm
Both examples in C and Java produce a sample binary KNIRecodeFile
. It recodes an input file to an output file, using a Khiops dictionary from a dictionary file.
KNIRecodeFile <Dictionary file> <Dictionary> <Input File> <Output File> [Error file]
# The input file must have a header line, describing the structure of all its instances.
# The input and output files have a tabular format.
# The error file may be useful for debugging purposes. It is optional and may be empty.
A more complex example (available only in C) is KNIRecodeMTFiles
, it recodes the input files of multi-table dataset to a single output file.
KNIRecodeMTFiles
-d: <input dictionary file> <input dictionary>
[-f: <field separator>
-i: <input file name> [<key index>...]
-s: <secondary data path> < file name> <key index>...
-x: <external data root> <external data path> <external file name>
-o: <output file name>
[-e: <error file name>]
[-m: <max memory (MB)>]
The files are located in cpp directory. They allow to build KNIRecodeFile
and KNIRecodeMTFiles
.
On Linux:
gcc -o KNIRecodeFile cpp/KNIRecodeFile.c -I /usr/include/ -lKhiopsNativeInterface -ldl
gcc -o KNIRecodeMTFiles cpp/KNIRecodeMTFiles.c -I /usr/include/ -lKhiopsNativeInterface -ldl
On Windows, open a "Visual Studio Developer Console" and run:
cl cpp/KNIRecodeFile.c %KNI_HOME%\lib\KhiopsNativeInterface.lib ^
-I %KNI_HOME%\include /link "/LIBPATH:%KNI_HOME%\bin"
cl cpp/KNIRecodeMTFiles.c %KNI_HOME%\lib\KhiopsNativeInterface.lib ^
-I %KNI_HOME%\include /link "/LIBPATH:%KNI_HOME%\bin"
Recode the "Iris" dataset from the data directory using the SNB_Iris dictionary.
KNIRecodeFile data/ModelingIris.kdic SNB_Iris data/Iris.txt R_Iris.txt
Recode the "Splice Junction" multi-table dataset using the SNB_SpliceJunction
classifier dictionary.
KNIRecodeMTFiles -d data/ModelingSpliceJunction.kdic SNB_SpliceJunction \
-i .data/SpliceJunction.txt 1 -s DNA data/SpliceJunctionDNA.txt 1 -o R_SpliceJunction.txt
The files are located in java directory. They allow to build KNIRecodeFile.jar
. This example use JNA to make calls to KhiopsNativeInterface.so/dll from Java.
To compile Java files and create the kni.jar
file:
javac -cp jna.jar java/KNIRecodeFile.java java/KNI.java
jar cf kni.jar -C java KNI.class -C java KNIRecodeFile.class
Recodes the "Iris" dataset from the data directory using the SNB_Iris
classifier dictionary.
On Linux:
java -cp kni.jar:jna.jar KNIRecodeFile data/ModelingIris.kdic SNB_Iris \
data/Iris.txt R_Iris_java.txt
On Windows:
set path=%KNI_HOME%/bin;%path%
java -cp kni.jar;jna.jar KNIRecodeFile data/ModelingIris.kdic SNB_Iris ^
data/Iris.txt R_Iris_java.txt