| // Float simple_mul bytecode loading and input/output processes |
| |
| #include "iree/base/api.h" |
| #include "iree/hal/api.h" |
| #include "samples/util/util.h" |
| |
| // Compiled module embedded here to avoid file IO: |
| #if !defined(BUILD_EMITC_STATIC) |
| #include "samples/simple_vec_mul/simple_float_mul_bytecode_module_dylib_c.h" |
| #else |
| #include "samples/simple_vec_mul/simple_float_mul_c_module_static_c.h" |
| #include "samples/simple_vec_mul/simple_float_mul_c_module_static_emitc.h" |
| #endif |
| |
| const MlModel kModel = { |
| .num_input = 2, |
| .num_input_dim = {1, 1}, |
| .input_shape = {{1024}, {1024}}, |
| .input_length = {1024, 1024}, |
| .input_size_bytes = {sizeof(float), sizeof(float)}, |
| .num_output = 1, |
| .output_length = {1024}, |
| .output_size_bytes = sizeof(float), |
| .hal_element_type = IREE_HAL_ELEMENT_TYPE_FLOAT_32, |
| .entry_func = "module.simple_mul", |
| .model_name = "simple_float_vec_mul", |
| }; |
| |
| #if !defined(BUILD_EMITC_STATIC) |
| const iree_const_byte_span_t load_bytecode_module_data() { |
| const struct iree_file_toc_t *module_file_toc = |
| samples_simple_vec_mul_simple_float_mul_bytecode_module_dylib_create(); |
| return iree_make_const_byte_span(module_file_toc->data, |
| module_file_toc->size); |
| } |
| #else |
| // Function to create the C module. |
| iree_status_t create_c_module(iree_vm_module_t **module) { |
| return module_create(iree_allocator_system(), module); |
| } |
| |
| const iree_hal_executable_library_header_t **library_query( |
| iree_hal_executable_library_version_t max_version, void *reserved) { |
| return simple_mul_dispatch_0_library_query(max_version, |
| /*reserved=*/reserved); |
| } |
| #endif |
| |
| iree_status_t load_input_data(const MlModel *model, void **buffer, |
| iree_byte_span_t **byte_span) { |
| iree_status_t result = alloc_input_buffer(model, buffer); |
| // Populate initial values |
| // arg0 = 0, 1/4, 1/2, 3/4... 1023/4 |
| // arg1 = 0, 1/2, 1, 3/2... 1023/2 |
| if (iree_status_is_ok(result)) { |
| for (int i = 0; i < model->input_length[0]; ++i) { |
| ((float *)buffer[0])[i] = i / 4.0f; |
| ((float *)buffer[1])[i] = i / 2.0f; |
| } |
| } |
| for (int i = 0; i < model->num_input; ++i) { |
| byte_span[i] = malloc(sizeof(iree_byte_span_t)); |
| *byte_span[i] = iree_make_byte_span( |
| buffer[i], model->input_size_bytes[i] * model->input_length[i]); |
| } |
| return result; |
| } |
| |
| iree_status_t process_output(const MlModel *model, |
| iree_hal_buffer_mapping_t *buffers, |
| MlOutput *output) { |
| iree_status_t result = iree_ok_status(); |
| for (int i = 0; i < buffers[0].contents.data_length / sizeof(float); |
| ++i) { |
| if (((const float *)buffers[0].contents.data)[i] != i * i / 8.0f) { |
| result = iree_make_status(IREE_STATUS_UNKNOWN, "result mismatches"); |
| break; |
| } |
| } |
| return result; |
| } |