Skip to content

Commit

Permalink
SDK release v1.50.17
Browse files Browse the repository at this point in the history
  • Loading branch information
francovaro committed Jun 4, 2024
1 parent ed26ab8 commit dba9534
Show file tree
Hide file tree
Showing 8 changed files with 3,267 additions and 105 deletions.
9 changes: 6 additions & 3 deletions EdgeImpulse.EI-SDK.pdsc
Original file line number Diff line number Diff line change
Expand Up @@ -5,13 +5,16 @@
<name>EI-SDK</name>
<license>LICENSE-apache-2.0.txt</license>
<description>Edge Impulse SDK</description>
<url>https://github.com/edgeimpulse/edge-impulse-sdk-pack/releases/download/v1.50.14/</url>
<url>https://github.com/edgeimpulse/edge-impulse-sdk-pack/releases/download/v1.50.17/</url>
<supportContact>[email protected]</supportContact>
<repository type="git">https://github.com/edgeimpulse/edge-impulse-sdk-pack.git</repository>
<releases>
<release version="1.50.14" tag="v1.50.14" date="2024-06-03" url="https://github.com/edgeimpulse/edge-impulse-sdk-pack/releases/download/v1.50.14/EdgeImpulse.EI-SDK.1.50.14.pack">
<release version="1.50.17" tag="v1.50.17" date="2024-06-04" url="https://github.com/edgeimpulse/edge-impulse-sdk-pack/releases/download/v1.50.17/EdgeImpulse.EI-SDK.1.50.17.pack">
EI-SDK
</release>
<release version="1.50.14" tag="v1.50.14" date="2024-06-03" url="https://github.com/edgeimpulse/edge-impulse-sdk-pack/releases/download/v1.50.14/EdgeImpulse.EI-SDK.1.50.14.pack">
EI-SDK
</release>
<release version="1.50.13" tag="v1.50.13" date="2024-05-30" url="https://github.com/edgeimpulse/edge-impulse-sdk-pack/releases/download/v1.50.13/EdgeImpulse.EI-SDK.1.50.13.pack">
EI-SDK
</release>
Expand Down Expand Up @@ -143,7 +146,7 @@
</packages>
</requirements>
<components>
<component Cclass="EdgeImpulse" Cgroup="SDK" Cversion="1.50.14">
<component Cclass="EdgeImpulse" Cgroup="SDK" Cversion="1.50.17">
<description>Edge Impulse SDK</description>
<!-- short component description -->
<files>
Expand Down
4 changes: 2 additions & 2 deletions EdgeImpulse.pidx
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,8 @@
<index schemaVersion="1.0.0" xs:noNamespaceSchemaLocation="PackIndex.xsd" xmlns:xs="http://www.w3.org/2001/XMLSchema-instance">
<vendor>EdgeImpulse</vendor>
<url>https://raw.githubusercontent.com/edgeimpulse/edge-impulse-sdk-pack/main/</url>
<timestamp>2024-06-03 11:59:55</timestamp>
<timestamp>2024-06-04 10:22:30</timestamp>
<pindex>
<pdsc url="https://github.com/edgeimpulse/edge-impulse-sdk-pack/releases/download/v1.50.14/" vendor="EdgeImpulse" name="EI-SDK" version="1.50.14"/>
<pdsc url="https://github.com/edgeimpulse/edge-impulse-sdk-pack/releases/download/v1.50.17/" vendor="EdgeImpulse" name="EI-SDK" version="1.50.17"/>
</pindex>
</index>
2,582 changes: 2,582 additions & 0 deletions edgeimpulse/edge-impulse-sdk/Doxyfile

Large diffs are not rendered by default.

213 changes: 212 additions & 1 deletion edgeimpulse/edge-impulse-sdk/classifier/ei_classifier_types.h
Original file line number Diff line number Diff line change
Expand Up @@ -26,53 +26,264 @@
#define EI_CLASSIFIER_MAX_OBJECT_DETECTION_COUNT 10
#endif

/**
* @defgroup ei_structs Structs
*
* Public-facing structs for Edge Impulse C++ SDK.
*
* @addtogroup ei_structs
* @{
*/

/**
* @brief Holds the output of inference, anomaly results, and timing information.
*
* `ei_impulse_result_t` holds the output of `run_classifier()`. If object detection is
* enabled, then the output results is a
* pointer to an array of bounding boxes of size `bounding_boxes_count`, as given by
* [ei_impulse_result_bounding_box_t](https://docs.edgeimpulse.com/reference/ei_impulse_result_bounding_box_t).
* Otherwise, results are stored as an array of classification scores, as given by
* [ei_impulse_result_classification_t](https://docs.edgeimpulse.com/reference/ei_impulse_result_classification_t).
*
* If anomaly detection is enabled (e.g. `EI_CLASSIFIER_HAS_ANOMALY == 1`), then the
* anomaly score will be stored as a floating point value in `anomaly`.
*
* Timing information is stored in an
* [ei_impulse_result_timing_t](https://docs.edgeimpulse.com/reference/ei_impulse_result_timing_t)
* struct.
*
* **Source**: [classifier/ei_classifier_types.h](https://github.com/edgeimpulse/inferencing-sdk-cpp/blob/master/classifier/ei_classifier_types.h)
*
* **Example**: [standalone inferencing main.cpp](https://github.com/edgeimpulse/example-standalone-inferencing/blob/master/source/main.cpp)
*/
typedef struct {
/**
* Label of the detected object
*/
const char *label;

/**
* Value of the detected object
*/
float value;
} ei_impulse_result_classification_t;

/**
* @brief Holds the output of visual anomaly detection (FOMO-AD)
*
* If visual anomaly detection is enabled (e.g. `EI_CLASSIFIER_HAS_VISUAL_ANOMALY ==
* 1`), then the output results will be a pointer to an array of grid cells of size
* `visual_ad_count`, as given by
* [ei_impulse_result_bounding_box_t](https://docs.edgeimpulse.com/reference/ei_impulse_result_bounding_box_t).
*
* The visual anomaly detection result is stored in `visual_ad_result`, which contains the mean and max values of the grid cells.
*
* **Source**: [classifier/ei_classifier_types.h](https://github.com/edgeimpulse/inferencing-sdk-cpp/blob/master/classifier/ei_classifier_types.h)
*
* **Example**: [standalone inferencing main.cpp](https://github.com/edgeimpulse/example-standalone-inferencing/blob/master/source/main.cpp)
*/
typedef struct {
/**
* Mean value of the grid cells
*/
float mean_value;

/**
* Max value of the grid cells
*/
float max_value;
} ei_impulse_visual_ad_result_t;

/**
* @brief Holds information for a single bounding box.
*
* If object detection is enabled (i.e. `EI_CLASSIFIER_OBJECT_DETECTION == 1`), then
* inference results will be one or more bounding boxes. The bounding boxes with the
* highest confidence scores (assuming those scores are equal to or greater than
* `EI_CLASSIFIER_OBJECT_DETECTION_THRESHOLD`), given by the `value` member, are
* returned from inference. The total number of bounding boxes returned will be at
* least `EI_CLASSIFIER_OBJECT_DETECTION_COUNT`. The exact number of bounding boxes
* is stored in `bounding_boxes_count` field of [ei_impulse_result_t]/C++ Inference
* SDK Library/structs/ei_impulse_result_t.md).
*
* A bounding box is a rectangle that ideally surrounds the identified object. The
* (`x`, `y`) coordinates in the struct identify the top-left corner of the box.
* `label` is the predicted class with the highest confidence score. `value` is the
* confidence score between [0.0..1.0] of the given `label`.
*
* **Source**: [classifier/ei_classifier_types.h](https://github.com/edgeimpulse/inferencing-sdk-cpp/blob/master/classifier/ei_classifier_types.h)
*
* **Example**: [standalone inferencing main.cpp](https://github.com/edgeimpulse/example-standalone-inferencing/blob/master/source/main.cpp)
*/
typedef struct {
/**
* Pointer to a character array describing the associated class of the given
* bounding box. Taken from one of the elements of
* `ei_classifier_inferencing_categories[]`.
*/
const char *label;

/**
* x coordinate of the top-left corner of the bounding box
*/
uint32_t x;

/**
* y coordinate of the top-left corner of the bounding box
*/
uint32_t y;

/**
* Width of the bounding box
*/
uint32_t width;

/**
* Height of the bounding box
*/
uint32_t height;

/**
* Confidence score of the label describing the bounding box
*/
float value;
} ei_impulse_result_bounding_box_t;

/**
* @brief Holds timing information about the processing (DSP) and inference blocks.
*
* Records timing information during the execution of the preprocessing (DSP) and
* inference blocks. Can be used to determine if inference will meet timing requirements
* on your particular platform.
*
* **Source**: [classifier/ei_classifier_types.h](https://github.com/edgeimpulse/inferencing-sdk-cpp/blob/master/classifier/ei_classifier_types.h)
*
* **Example**: [standalone inferencing main.cpp](https://github.com/edgeimpulse/example-standalone-inferencing/blob/master/source/main.cpp)
*/
typedef struct {
/**
* If using `run_impulse()` to perform sampling and inference, it is the amount of
* time (in milliseconds) it took to fetch raw samples. Not used for
* `run_classifier()`.
*/
int sampling;

/**
* Amount of time (in milliseconds) it took to run the preprocessing (DSP) block
*/
int dsp;

/**
* Amount of time (in milliseconds) it took to run the inference block
*/
int classification;

/**
* Amount of time (in milliseconds) it took to run anomaly detection. Valid only if
* `EI_CLASSIFIER_HAS_ANOMALY == 1`.
*/
int anomaly;

/**
* Amount of time (in milliseconds) it took to run the post-processing block
*/
int64_t dsp_us;

/**
* Amount of time (in milliseconds) it took to run the inference block
*/
int64_t classification_us;

/**
* Amount of time (in microseconds) it took to run anomaly detection. Valid only if
* `EI_CLASSIFIER_HAS_ANOMALY == 1`.
*/
int64_t anomaly_us;
} ei_impulse_result_timing_t;

/**
* @brief Holds the output of inference, anomaly results, and timing information.
*
* `ei_impulse_result_t` holds the output of `run_classifier()`. If object detection is
* enabled (e.g. `EI_CLASSIFIER_OBJECT_DETECTION == 1`), then the output results is a
* pointer to an array of bounding boxes of size `bounding_boxes_count`, as given by
* [ei_impulse_result_bounding_box_t](https://docs.edgeimpulse.com/reference/ei_impulse_result_bounding_box_t).
* Otherwise, results are stored as an array of classification scores, as given by
* [ei_impulse_result_classification_t](https://docs.edgeimpulse.com/reference/ei_impulse_result_classification_t).
*
* If anomaly detection is enabled (e.g. `EI_CLASSIFIER_HAS_ANOMALY == 1`), then the
* anomaly score will be stored as a floating point value in `anomaly`.
*
* Timing information is stored in an
* [ei_impulse_result_timing_t](https://docs.edgeimpulse.com/reference/ei_impulse_result_timing_t)
* struct.
*
* **Source**: [classifier/ei_classifier_types.h](https://github.com/edgeimpulse/inferencing-sdk-cpp/blob/master/classifier/ei_classifier_types.h)
*
* **Example**: [standalone inferencing main.cpp](https://github.com/edgeimpulse/example-standalone-inferencing/blob/master/source/main.cpp)
*/
typedef struct {
/**
* Array of bounding boxes of the detected objects, if object detection is enabled.
*/
ei_impulse_result_bounding_box_t *bounding_boxes;

/**
* Number of bounding boxes detected. If object detection is not enabled, this will
* be 0.
*/
uint32_t bounding_boxes_count;

/**
* Array of classification results. If object detection is enabled, this will be
* empty.
*/
#if EI_CLASSIFIER_LABEL_COUNT == 0
// EI_CLASSIFIER_LABEL_COUNT can be 0 for anomaly only models
// to prevent compiler warnings/errors, we need to have at least one element
ei_impulse_result_classification_t classification[1];
#else
ei_impulse_result_classification_t classification[EI_CLASSIFIER_LABEL_COUNT];
#endif

/**
* Anomaly score. If anomaly detection is not enabled, this will be 0. A higher
* anomaly score indicates greater likelihood of an anomalous sample (e.g. it is
* farther away from its cluster).
*/
float anomaly;

/**
* Timing information for the processing (DSP) and inference blocks.
*/
ei_impulse_result_timing_t timing;

/**
* Copy the output data to a buffer. If set to false, the output data will be
* returned as a pointer to the internal buffer. If set to true, the output data
* will be copied to the buffer provided in `ei_impulse_output_t`.
*/
bool copy_output;
#if EI_CLASSIFIER_HAS_VISUAL_ANOMALY
#if EI_CLASSIFIER_HAS_VISUAL_ANOMALY || __DOXYGEN__
/**
* Array of grid cells of the detected visual anomalies, if visual anomaly detection
* is enabled.
*/
ei_impulse_result_bounding_box_t *visual_ad_grid_cells;

/**
* Number of grid cells detected as visual anomalies, if visual anomaly detection is
* enabled.
*/
uint32_t visual_ad_count;

/**
* Visual anomaly detection result, if visual anomaly detection is enabled.
*/
ei_impulse_visual_ad_result_t visual_ad_result;
#endif // EI_CLASSIFIER_HAS_VISUAL_ANOMALY
} ei_impulse_result_t;

/** @} */

#endif // _EDGE_IMPULSE_RUN_CLASSIFIER_TYPES_H_
Loading

0 comments on commit dba9534

Please sign in to comment.