blob: 379eb0f6ed6bd851b7883f81b71067b0d2821a83 [file] [log] [blame]
// Person_detection quant model
// MlModel struct initialization to include model I/O info.
// Bytecode loading, input/output processes.
#include <springbok.h>
#include "iree/base/api.h"
#include "iree/hal/api.h"
#include "samples/util/util.h"
#include "person_detection.h"
// Compiled module embedded here to avoid file IO:
#include "samples/quant_model/person_detection_bytecode_module_dylib_c.h"
#include "samples/quant_model/person_detection_quant_input_c.h"
const MlModel kModel = {
.num_input = 1,
.num_input_dim = {4},
.input_shape = {{1, 96, 96, 1}},
.input_length = {96 * 96 * 1},
.input_size_bytes = {sizeof(int8_t)},
.num_output = 1,
.output_length = {2},
.output_size_bytes = sizeof(int8_t),
.hal_element_type = IREE_HAL_ELEMENT_TYPE_SINT_8,
.entry_func = "module.main",
.model_name = "person_detection_quant",
};
PersonDetectionOutput detection;
const iree_const_byte_span_t load_bytecode_module_data() {
const struct iree_file_toc_t *module_file_toc =
samples_quant_model_person_detection_bytecode_module_dylib_create();
return iree_make_const_byte_span(module_file_toc->data,
module_file_toc->size);
}
iree_status_t load_input_data(const MlModel *model, void **buffer,
iree_byte_span_t **byte_span) {
byte_span[0] = malloc(sizeof(iree_byte_span_t));
*byte_span[0] =
iree_make_byte_span(person_detection_quant_input,
model->input_size_bytes[0] * model->input_length[0]);
return iree_ok_status();
}
iree_status_t process_output(const MlModel *model,
iree_hal_buffer_mapping_t *buffers,
MlOutput *output) {
iree_status_t result = iree_ok_status();
int8_t *data = (int8_t *)buffers[0].contents.data;
detection.non_person_score = data[0];
detection.person_score = data[1];
LOG_INFO("Output: Non-person Score: %d; Person Score: %d",
detection.non_person_score,
detection.person_score);
output->result = &detection;
output->len = sizeof(detection);
return result;
}