Getting started
Instantiating the client
First, instantiate a client with the URL of your deployment and your personal token:
import {Client} from "@ikomia/ikclient";
const client = new Client({
url: "https://your.scale.endpoint.url",
// token: "your-api-token", default to process.env.IKOMIA_TOKEN
});
...
We strongly recommend avoiding exposing your personal token in your code.
You can set IKOMIA_TOKEN
as an environment variable to avoid passing it explicitly.
Running deployment
To run your deployment, simply call client.run
optionally passing input image(s) and parameters, and await the results:
const results = await client.run({
image: "https://raw.githubusercontent.com/Ikomia-dev/notebooks/main/examples/img/img_work.jpg"
});
Use the image
attribute to pass an input image to your deployment. You can pass an URL, a base64 encoded string, a Buffer
, an ArrayBuffer
, a Uint8Array
or a Blob
.
If your deployment takes multiple images as inputs, use the images
attribute instead of image
and pass an array of input images.
const results = await client.run({
images: [
"https://raw.githubusercontent.com/Ikomia-dev/notebooks/main/examples/img/img_work.jpg",
"https://raw.githubusercontent.com/Ikomia-dev/notebooks/main/examples/img/img_starry_night.jpg"
]
});
The results
object contains the output of your deployment. The number, type and value of your outputs depend on the deployment you are running,
its settings and the inputs you provided.
By default, your results will contains all the outputs returned by the first leaf task in your workflow. In the common usecase where your workflow is a simple chain of algorithms, this will correspond to the outputs of the last algorithm of the chain.
If you want to run another task in your workflow, you can specify the taskName
attribute in the run
method:
const results = await client.run({
taskName: "infer_yolo_v10",
image: "https://raw.githubusercontent.com/Ikomia-dev/notebooks/main/examples/img/img_work.jpg"
});
You can also set parameters for the output task using the parameters
attribute:
const results = await client.run({
taskName: "infer_mobile_segment_anything", // Default to the first leaf task
image: "https://raw.githubusercontent.com/Ikomia-dev/notebooks/main/examples/img/img_work.jpg",
parameters: {
iou_thres: 0.88,
cuda: true
}
});
Tracking progress
You can track the progress of your deployment by adding an onProgress
callback:
const results = await client.run({
image: "https://raw.githubusercontent.com/Ikomia-dev/notebooks/main/examples/img/img_work.jpg",
onProgress: (progress) => {
// {"runId": "v4d4mg96bu", "name": "EdgeDetection", "state": "PENDING", "uuid": "10591168-ba4b-4356-9d76-47de902a118e", "eta": [1000, 20000]}
console.log(progress);
}
});
This callback will be called multiple time during the polling process of the deployment.
It passes an object containing the current state of the deployment execution and an interval of the estimated execution time in milliseconds (eta
).
Accessing the results
To access the results, you can use results.getOutput
method:
import {ImageIO, ObjectDetectionIO} from "@ikomia/ikclient/io";
const image = results.getOutput<ImageIO>(0);
// const image = results.getOutput(0); // If you don't use TypeScript
const objectDetection = results.getOutput<ObjectDetectionIO>(1);
The getOutput
method returns the output of the specified index.
If you are using TypeScript, you can pass a type argument to assert what type of output you expect to retrieve, which will help with autocompletion. We support the following standard types:
ImageIO
for image outputsInstanceSegmentationIO
for instance segmentationKeypointsIO
for keypoints or pose estimationSemanticSegmentationIO
for semantic segmentationObjectDetectionIO
for object detectionTextIO
for OCR or text detection
Non-standard types are returned as the base generic type TaskIO
.
You can also use the results.getOutputs
method to get all outputs as an array:
const [image, objectDetection] = results.getOutputs<[ImageIO, ObjectDetectionIO]>();
// const [image, objectDetection] = results.getOutputs(); // If you don't use TypeScript