#pragma once #include #include "cereal/messaging/messaging.h" #include "common/util.h" #include "selfdrive/modeld/models/commonmodel.h" #include "selfdrive/modeld/runners/run.h" #define CALIB_LEN 3 #define OUTPUT_SIZE 45 #define REG_SCALE 0.25f typedef struct DMonitoringResult { float face_orientation[3]; float face_orientation_meta[3]; float face_position[2]; float face_position_meta[2]; float face_prob; float left_eye_prob; float right_eye_prob; float left_blink_prob; float right_blink_prob; float sg_prob; float poor_vision; float partial_face; float distracted_pose; float distracted_eyes; float occluded_prob; float ready_prob[4]; float not_ready_prob[2]; float dsp_execution_time; } DMonitoringResult; typedef struct DMonitoringModelState { RunModel *m; bool is_rhd; float output[OUTPUT_SIZE]; std::vector resized_buf; std::vector cropped_buf; std::vector premirror_cropped_buf; std::vector net_input_buf; float calib[CALIB_LEN]; float tensor[UINT8_MAX + 1]; } DMonitoringModelState; void dmonitoring_init(DMonitoringModelState* s); DMonitoringResult dmonitoring_eval_frame(DMonitoringModelState* s, void* stream_buf, int width, int height, int stride, int uv_offset, float *calib); void dmonitoring_publish(PubMaster &pm, uint32_t frame_id, const DMonitoringResult &res, float execution_time, kj::ArrayPtr raw_pred); void dmonitoring_free(DMonitoringModelState* s);