| Data Structures | |
| class | BufferPool | 
| Template class for buffer pool of the specified buffer type.  More... | |
| class | DlLibHandle | 
| Helper class for dynamic loading of custom library.  More... | |
| class | GuardQueue | 
| Template class for creating a thread safe queue for the given container class.  More... | |
| class | MapBufferPool | 
| Template class for a map of buffer pools.  More... | |
| class | QueueThread | 
| Template class for running the specified function on the queue items in a separate thread.  More... | |
| class | WakeupException | 
| Wrapper class for handling exception.  More... | |
| Typedefs | |
| template<class UniPtr > | |
| using | SharedBufPool = std::shared_ptr< BufferPool< UniPtr > > | 
| Functions | |
| void | dsInferLogPrint__ (NvDsInferLogLevel level, const char *fmt,...) | 
| Print the nvinferserver log messages as per the configured log level.  More... | |
| void | dsInferLogVPrint__ (NvDsInferLogLevel level, const char *fmt, va_list args) | 
| Helper function to print the nvinferserver logs.  More... | |
| bool | string_empty (const char *str) | 
| Helper function, returns true if the input C string is empty or null.  More... | |
| template<typename T > | |
| bool | isNonBatch (T b) | 
| Checks if the input batch size is zero.  More... | |
| bool | fEqual (float a, float b) | 
| Check if the two floating point values are equal, the difference is less than or equal to the epsilon value.  More... | |
| uint32_t | getElementSize (InferDataType t) | 
| Get the size of the element from the data type.  More... | |
| bool | hasWildcard (const InferDims &dims) | 
| Check if any of the InferDims dimensions are of dynamic size (-1 or negative values).  More... | |
| size_t | dimsSize (const InferDims &dims) | 
| Calculate the total number of elements for the given dimensions.  More... | |
| void | normalizeDims (InferDims &dims) | 
| Recalculates the total number of elements for the dimensions.  More... | |
| NvDsInferLayerInfo | toCapi (const LayerDescription &desc, void *bufPtr) | 
| Convert the layer description and buffer pointer to NvDsInferLayerInfo of the interface.  More... | |
| NvDsInferDims | toCapi (const InferDims &dims) | 
| Convert the InferDims to NvDsInferDims of the library interface.  More... | |
| NvDsInferLayerInfo | toCapiLayerInfo (const InferBufferDescription &desc, void *buf=nullptr) | 
| Generate NvDsInferLayerInfo of the interface from the buffer description and buffer pointer.  More... | |
| NvDsInferDataType | toCapiDataType (InferDataType dt) | 
| Convert the InferDataType to NvDsInferDataType of the library interface.  More... | |
| bool | intersectDims (const InferDims &a, const InferDims &b, InferDims &c) | 
| Get the intersection of the two input dimensions.  More... | |
| bool | isPrivateTensor (const std::string &tensorName) | 
| Check if the given tensor is marked as private (contains INFER_SERVER_PRIVATE_BUF in the name).  More... | |
| bool | isCpuMem (InferMemType type) | 
| Check if the memory type uses CPU memory (kCpu or kCpuCuda).  More... | |
| std::string | memType2Str (InferMemType type) | 
| Returns a string object corresponding to the InferMemType name.  More... | |
| InferDims | fullDims (int batchSize, const InferDims &in) | 
| Extend the dimensions to include batch size.  More... | |
| bool | debatchFullDims (const InferDims &full, InferDims &debatched, uint32_t &batch) | 
| Separates batch size from given dimensions.  More... | |
| bool | squeezeMatch (const InferDims &a, const InferDims &b) | 
| Check that the two dimensions are equal ignoring single element values.  More... | |
| SharedBatchBuf | ReshapeBuf (const SharedBatchBuf &in, uint32_t batch, const InferDims &dims, bool reCalcBytes=false) | 
| Update the buffer dimensions as per provided new dimensions.  More... | |
| SharedBatchBuf | reshapeToFullDimsBuf (const SharedBatchBuf &buf, bool reCalcBytes=false) | 
| Reshape the buffer dimensions with batch size added as new dimension.  More... | |
| NvDsInferStatus | tensorBufferCopy (const SharedBatchBuf &in, const SharedBatchBuf &out, const SharedCuStream &stream) | 
| Copy one tensor buffer to another.  More... | |
| using INFER_EXPORT_API::SharedBufPool = typedef std::shared_ptr<BufferPool<UniPtr> > | 
Definition at line 493 of file infer_utils.h.
| std::string INFER_EXPORT_API::batchDims2Str | ( | const InferBatchDims & | d | ) | 
| std::string INFER_EXPORT_API::dataType2GrpcStr | ( | const InferDataType | type | ) | 
| std::string INFER_EXPORT_API::dataType2Str | ( | const InferDataType | type | ) | 
| bool INFER_EXPORT_API::debatchFullDims | ( | const InferDims & | full, | 
| InferDims & | debatched, | ||
| uint32_t & | batch | ||
| ) | 
Separates batch size from given dimensions.
| [in] | full | Input full dimensions with batch size. | 
| [out] | debatched | Output dimensions without the batch size. | 
| [out] | batch | Batch size of the input dimensions. | 
| NvDsInferNetworkInfo INFER_EXPORT_API::dims2ImageInfo | ( | const InferDims & | d, | 
| InferTensorOrder | order | ||
| ) | 
| std::string INFER_EXPORT_API::dims2Str | ( | const InferDims & | d | ) | 
Helper functions to convert the various data types to string values for debug, log information.
| 
 | inline | 
Calculate the total number of elements for the given dimensions.
| dims | Input Input dimensions. | 
Definition at line 670 of file infer_utils.h.
References hasWildcard().
Referenced by normalizeDims().
| std::string INFER_EXPORT_API::dirName | ( | const std::string & | path | ) | 
| void INFER_EXPORT_API::dsInferLogVPrint__ | ( | NvDsInferLogLevel | level, | 
| const char * | fmt, | ||
| va_list | args | ||
| ) | 
Helper function to print the nvinferserver logs.
This functions prints the log message to stderr or stdout depending on the input level. If the input level is more that the log level configured by the environment variable NVDSINFERSERVER_LOG_LEVEL (default level NVDSINFER_LOG_INFO), the log message is discarded. Messages of level NVDSINFER_LOG_ERROR are output to stderr others to stdout. A global mutex is used to guard concurrent prints from multiple threads.
| [in] | level | Log level of the message. | 
| [in] | fmt | The fprintf format string of the log message. | 
| [in] | args | The variable argument list for fprintf. | 
| bool INFER_EXPORT_API::fEqual | ( | float | a, | 
| float | b | ||
| ) | 
Check if the two floating point values are equal, the difference is less than or equal to the epsilon value.
| 
 | inline | 
Helper functions to check if the input file path is valid and accessible.
Definition at line 86 of file infer_utils.h.
| 
 | inline | 
Definition at line 91 of file infer_utils.h.
| InferDims INFER_EXPORT_API::fullDims | ( | int | batchSize, | 
| const InferDims & | in | ||
| ) | 
Extend the dimensions to include batch size.
| [in] | batchSize | Input batch size. | 
| [in] | in | Input dimensions. | 
Referenced by nvdsinfer::convertFullDims().
| 
 | inline | 
Get the size of the element from the data type.
Definition at line 624 of file infer_utils.h.
References InferError.
| InferDataType INFER_EXPORT_API::grpcStr2DataType | ( | const std::string & | type | ) | 
| 
 | inline | 
Check if any of the InferDims dimensions are of dynamic size (-1 or negative values).
Definition at line 656 of file infer_utils.h.
Referenced by nvdsinferserver::DimsFromTriton(), and dimsSize().
| bool INFER_EXPORT_API::intersectDims | ( | const InferDims & | a, | 
| const InferDims & | b, | ||
| InferDims & | c | ||
| ) | 
Get the intersection of the two input dimensions.
This functions derives the intersections of the two input dimensions by replacing the wild card dimensions (dynamic sized) with the corresponding value from the other input. The functions returns failure if the two inputs have different number of dimensions or if the two corresponding dimensions are of fixed size but different.
| [in] | a | First input dimensions. | 
| [in] | b | Second input dimensions. | 
| [out] | c | The derived output intersection. | 
| bool INFER_EXPORT_API::isAbsolutePath | ( | const std::string & | path | ) | 
| bool INFER_EXPORT_API::isCpuMem | ( | InferMemType | type | ) | 
Check if the memory type uses CPU memory (kCpu or kCpuCuda).
| 
 | inline | 
Checks if the input batch size is zero.
Definition at line 101 of file infer_utils.h.
Referenced by nvdsinferserver::BaseBackend::isNonBatching().
| bool INFER_EXPORT_API::isPrivateTensor | ( | const std::string & | tensorName | ) | 
Check if the given tensor is marked as private (contains INFER_SERVER_PRIVATE_BUF in the name).
Private tensors are skipped in inference output processing.
| std::string INFER_EXPORT_API::joinPath | ( | const std::string & | a, | 
| const std::string & | b | ||
| ) | 
Helper functions for parsing the configuration file.
| std::string INFER_EXPORT_API::memType2Str | ( | InferMemType | type | ) | 
Returns a string object corresponding to the InferMemType name.
| 
 | inline | 
Recalculates the total number of elements for the dimensions.
| dims | Input dimensions. | 
Definition at line 686 of file infer_utils.h.
References dimsSize().
| bool INFER_EXPORT_API::operator!= | ( | const InferDims & | a, | 
| const InferDims & | b | ||
| ) | 
| bool INFER_EXPORT_API::operator<= | ( | const InferDims & | a, | 
| const InferDims & | b | ||
| ) | 
Comparison operators for the InferDims type.
| bool INFER_EXPORT_API::operator== | ( | const InferDims & | a, | 
| const InferDims & | b | ||
| ) | 
| bool INFER_EXPORT_API::operator> | ( | const InferDims & | a, | 
| const InferDims & | b | ||
| ) | 
| bool INFER_EXPORT_API::realPath | ( | const std::string & | inPath, | 
| std::string & | absPath | ||
| ) | 
| SharedBatchBuf INFER_EXPORT_API::ReshapeBuf | ( | const SharedBatchBuf & | in, | 
| uint32_t | batch, | ||
| const InferDims & | dims, | ||
| bool | reCalcBytes = false | ||
| ) | 
Update the buffer dimensions as per provided new dimensions.
| [in] | in | Input batch buffer. | 
| [in] | batch | Expected batch size. | 
| [in] | dims | New buffer dimensions. | 
| [in] | reCalcBytes | Flag to enable recalculation of total number of bytes in buffer based on expected batch size and new dimensions. | 
| SharedBatchBuf INFER_EXPORT_API::reshapeToFullDimsBuf | ( | const SharedBatchBuf & | buf, | 
| bool | reCalcBytes = false | ||
| ) | 
Reshape the buffer dimensions with batch size added as new dimension.
| [in] | buf | Input batch buffer. | 
| [in] | reCalcBytes | Flag to enable recalculation of total number of bytes in buffer. | 
| 
 | inline | 
Helper functions to get a safe C-string representation for the input string.
Returns an empty string if the input pointer is null.
Definition at line 64 of file infer_utils.h.
| 
 | inline | 
Definition at line 68 of file infer_utils.h.
Referenced by INFER_EXPORT_API::BufferPool< UniPtr >::acquireBuffer(), INFER_EXPORT_API::MapBufferPool< Key, UniqBuffer >::acquireBuffer(), INFER_EXPORT_API::MapBufferPool< Key, UniqBuffer >::clear(), INFER_EXPORT_API::QueueThread< Container >::join(), INFER_EXPORT_API::BufferPool< UniPtr >::setBuffer(), INFER_EXPORT_API::MapBufferPool< Key, UniqBuffer >::setBuffer(), INFER_EXPORT_API::QueueThread< Container >::setThreadName(), INFER_EXPORT_API::DlLibHandle::symbol(), INFER_EXPORT_API::BufferPool< UniPtr >::~BufferPool(), and INFER_EXPORT_API::MapBufferPool< Key, UniqBuffer >::~MapBufferPool().
| bool INFER_EXPORT_API::squeezeMatch | ( | const InferDims & | a, | 
| const InferDims & | b | ||
| ) | 
Check that the two dimensions are equal ignoring single element values.
| [in] | a | First set of inference dimensions. | 
| [in] | b | Second set of inference dimensions. | 
| 
 | inline | 
Helper function, returns true if the input C string is empty or null.
Definition at line 77 of file infer_utils.h.
| NvDsInferStatus INFER_EXPORT_API::tensorBufferCopy | ( | const SharedBatchBuf & | in, | 
| const SharedBatchBuf & | out, | ||
| const SharedCuStream & | stream | ||
| ) | 
Copy one tensor buffer to another.
This functions copies the data from one batch buffer to another. Both the buffers must have the same total number of bytes. In case of copy to or from device memory cudaMemcpyAsync is used with the provided CUDA stream and GPU ID. For copy between host memory buffers memcpy is used.
| [in] | in | Source batch buffer. | 
| [out] | out | Destination btach buffer. | 
| [in] | stream | CUDA stream for use with cudaMemcpyAsync | 
| std::string INFER_EXPORT_API::tensorOrder2Str | ( | InferTensorOrder | order | ) | 
| NvDsInferDims INFER_EXPORT_API::toCapi | ( | const InferDims & | dims | ) | 
Convert the InferDims to NvDsInferDims of the library interface.
| NvDsInferLayerInfo INFER_EXPORT_API::toCapi | ( | const LayerDescription & | desc, | 
| void * | bufPtr | ||
| ) | 
Convert the layer description and buffer pointer to NvDsInferLayerInfo of the interface.
| NvDsInferDataType INFER_EXPORT_API::toCapiDataType | ( | InferDataType | dt | ) | 
Convert the InferDataType to NvDsInferDataType of the library interface.
| NvDsInferLayerInfo INFER_EXPORT_API::toCapiLayerInfo | ( | const InferBufferDescription & | desc, | 
| void * | buf = nullptr | ||
| ) | 
Generate NvDsInferLayerInfo of the interface from the buffer description and buffer pointer.