[FFmpeg-devel] [PATCH V4 1/4] libavfilter/bbox.h: add BoundingBoxHeader and BoundingBox
Guo, Yejun
yejun.guo at intel.com
Mon Mar 1 15:20:50 EET 2021
They will be used for filters such as detect and classify.
Signed-off-by: Guo, Yejun <yejun.guo at intel.com>
---
libavfilter/bbox.h | 53 ++++++++++++++++++++++++++++++++++++++++++++++
1 file changed, 53 insertions(+)
diff --git a/libavfilter/bbox.h b/libavfilter/bbox.h
index 116158d59e..ead14417cc 100644
--- a/libavfilter/bbox.h
+++ b/libavfilter/bbox.h
@@ -22,6 +22,59 @@
#define AVFILTER_BBOX_H
#include <stdint.h>
+#include "libavutil/rational.h"
+
+typedef struct BoundingBox {
+ /**
+ * Distance in pixels from the top edge of the frame to top
+ * and bottom, and from the left edge of the frame to left and
+ * right, defining the bounding box.
+ */
+ int top;
+ int left;
+ int bottom;
+ int right;
+
+#define BBOX_LABEL_NAME_MAX_LENGTH 32
+
+ /**
+ * Detect result with confidence
+ */
+ char detect_label[BBOX_LABEL_NAME_MAX_LENGTH+1];
+ AVRational detect_confidence;
+
+ /**
+ * At most 4 classifications based on the detected bounding box.
+ * For example, we can get max 4 different attributes with 4 different
+ * DNN models on one bounding box.
+ * classify_count is zero if no classification.
+ */
+#define AV_NUM_BBOX_CLASSIFY 4
+ uint32_t classify_count;
+ char classify_labels[AV_NUM_BBOX_CLASSIFY][BBOX_LABEL_NAME_MAX_LENGTH+1];
+ AVRational classify_confidences[AV_NUM_BBOX_CLASSIFY];
+} BoundingBox;
+
+typedef struct BoundingBoxHeader {
+ /**
+ * Information about how the bounding box is generated.
+ * for example, the DNN model name.
+ */
+ char source[128];
+
+ /**
+ * Must be set to the size of BoundingBox (that is,
+ * sizeof(BoundingBox)).
+ */
+ uint32_t bbox_size;
+
+ /**
+ * Pointer to the array of BoundingBox.
+ * Add one element here is to meet the possible
+ * alignment requirement of bboxes.
+ */
+ BoundingBox bboxes[1];
+} BoundingBoxHeader;
typedef struct FFBoundingBox {
int x1, x2, y1, y2;
--
2.17.1
More information about the ffmpeg-devel
mailing list