22#include <opencv2/core/core.hpp>
23#include <tensorflow/lite/c/common.h>
24#include <ovxlib/vsi_nn_pub.h>
27#include <hailo/hailort.h>
28#include <onnxruntime_cxx_api.h>
46 std::map<int, std::string>
readLabelsFile(std::string
const & fname);
50 std::string
getLabel(std::map<int, std::string>
const & labels,
int id);
53 int stringToRGBA(std::string
const & label,
unsigned char alpha = 128);
56 void topK(
float const * pfProb,
float * pfMaxProb, uint32_t * pMaxClass, uint32_t outputCount, uint32_t topNum);
59 std::string
shapestr(cv::Mat
const & m);
62 std::string
shapestr(TfLiteTensor
const * t);
65 std::string
shapestr(vsi_nn_tensor_attr_t
const & attr);
68 std::vector<size_t>
strshape(std::string
const & str);
71 int tf2cv(TfLiteType t);
74 vsi_nn_type_e
tf2vsi(TfLiteType t);
77 int vsi2cv(vsi_nn_type_e t);
80 void clamp(cv::Rect & r,
int width,
int height);
83 void clamp(cv::Rect2f & r,
float width,
float height);
87 std::vector<vsi_nn_tensor_attr_t>
parseTensorSpecs(std::string
const & specs);
94 cv::Mat
attrmat(vsi_nn_tensor_attr_t
const & attr,
void * dataptr =
nullptr);
97 std::vector<int>
attrdims(vsi_nn_tensor_attr_t
const & attr);
100 cv::Size
attrsize(vsi_nn_tensor_attr_t
const & attr);
103 std::string
attrstr(vsi_nn_tensor_attr_t
const & attr);
106 bool attrmatch(vsi_nn_tensor_attr_t
const & attr, cv::Mat
const & blob);
109 vsi_nn_tensor_attr_t
tensorattr(TfLiteTensor
const * t);
115 size_t softmax(
float const * input,
size_t const n,
size_t const stride,
float const fac,
float * output,
121 cv::Mat
quantize(cv::Mat
const & m, vsi_nn_tensor_attr_t
const & attr);
125 cv::Mat
dequantize(cv::Mat
const & m, vsi_nn_tensor_attr_t
const & attr);
137 cv::Mat
concatenate(std::vector<cv::Mat>
const & tensors,
int axis);
141 std::string
shapestr(hailo_vstream_info_t
const & vi);
144 vsi_nn_tensor_attr_t
tensorattr(hailo_vstream_info_t
const & vi);
147 vsi_nn_type_e
hailo2vsi(hailo_format_type_t t);
150 vsi_nn_type_e
onnx2vsi(ONNXTensorElementDataType t);
153 std::string
shapestr(Ort::ConstTensorTypeAndShapeInfo
const & ti);
156 vsi_nn_tensor_attr_t
tensorattr(Ort::ConstTensorTypeAndShapeInfo
const & ti);
int tf2cv(TfLiteType t)
Convert from TensorFlow data type to OpenCV.
int vsi2cv(vsi_nn_type_e t)
Convert from NPU data type to OpenCV.
size_t softmax(float const *input, size_t const n, size_t const stride, float const fac, float *output, bool maxonly)
Apply softmax to a float vector.
vsi_nn_tensor_attr_t tensorattr(TfLiteTensor const *t)
Get tensor shape and type attributes for a TensorFlow Lite tensor.
cv::Mat quantize(cv::Mat const &m, vsi_nn_tensor_attr_t const &attr)
Quantize from float32 to fixed-point according to the quantization spec in attr.
std::map< int, std::string > readLabelsFile(std::string const &fname)
Read a label file.
vsi_nn_type_e onnx2vsi(ONNXTensorElementDataType t)
Convert from ONNX-Runtime data type to vsi_nn.
std::vector< vsi_nn_tensor_attr_t > parseTensorSpecs(std::string const &specs)
Parse tensor specification.
void clamp(cv::Rect &r, int width, int height)
Clamp a rectangle to within given image width and height.
std::string attrstr(vsi_nn_tensor_attr_t const &attr)
Get a string describing the specs of a tensor, including quantification specs (not provided by shapes...
cv::Mat attrmat(vsi_nn_tensor_attr_t const &attr, void *dataptr=nullptr)
Construct a cv::Mat from attr and possibly data pointer.
size_t effectiveDims(cv::Mat const &m)
Returns the number of non-unit dims in a cv::Mat.
vsi_nn_type_e hailo2vsi(hailo_format_type_t t)
Convert from Hailo data type to vsi_nn.
cv::Mat concatenate(std::vector< cv::Mat > const &tensors, int axis)
Concatenate several tensors into one.
int stringToRGBA(std::string const &label, unsigned char alpha=128)
Compute a color from a label name.
cv::Size attrsize(vsi_nn_tensor_attr_t const &attr)
Get a tensor's (width, height) size in cv::Size format, skipping over other dimensions.
std::string getLabel(std::map< int, std::string > const &labels, int id)
Get a label from an id.
cv::Mat dequantize(cv::Mat const &m, vsi_nn_tensor_attr_t const &attr)
Dequantize an output to float32 according to the quantization spec in attr.
vsi_nn_type_e tf2vsi(TfLiteType t)
Convert from TensorFlow data type to vsi_nn.
void topK(float const *pfProb, float *pfMaxProb, uint32_t *pMaxClass, uint32_t outputCount, uint32_t topNum)
Get top-k entries and their indices.
std::string shapestr(cv::Mat const &m)
Get a string of the form: "nD AxBxC... TYPE" from an n-dimensional cv::Mat with data type TYPE.
std::vector< int > attrdims(vsi_nn_tensor_attr_t const &attr)
Get a tensor dims as a vector of int, useful to construct a matching cv::Mat.
std::vector< size_t > strshape(std::string const &str)
Get a vector of size_t from a string containing AxBxC...
bool attrmatch(vsi_nn_tensor_attr_t const &attr, cv::Mat const &blob)
Check that a cv::Mat blob matches exactly the spec of an attr.
Main namespace for all JeVois classes and functions.