#pragma once #ifdef VP_WITH_TRT #include "../vp_secondary_infer_node.h" #include "../../third_party/trt_yolov8/trt_yolov8_classifier.h" namespace vp_nodes { // universal yolov8 classifier based on tensorrt using third_party/trt_yolov8 library class vp_trt_yolov8_classifier: public vp_secondary_infer_node { private: /* data */ std::shared_ptr yolov8_classifier = nullptr; protected: // we need a totally new logic for the whole infer combinations // no separate step pre-defined needed in base class virtual void run_infer_combinations(const std::vector>& frame_meta_with_batch) override; // override pure virtual method, for compile pass virtual void postprocess(const std::vector& raw_outputs, const std::vector>& frame_meta_with_batch) override; public: vp_trt_yolov8_classifier(std::string node_name, std::string model_path, std::string labels_path = "", std::vector p_class_ids_applied_to = std::vector(), int min_width_applied_to = 0, int min_height_applied_to = 0); ~vp_trt_yolov8_classifier(); }; } #endif