#include #include #include #include #include "cereal/visionipc/visionipc_client.h" #include "selfdrive/common/swaglog.h" #include "selfdrive/common/util.h" #include "selfdrive/modeld/models/dmonitoring.h" ExitHandler do_exit; void run_model(DMonitoringModelState &model, VisionIpcClient &vipc_client) { PubMaster pm({"driverState"}); SubMaster sm({"liveCalibration"}); float calib[CALIB_LEN] = {0}; double last = 0; while (!do_exit) { VisionIpcBufExtra extra = {}; VisionBuf *buf = vipc_client.recv(&extra); if (buf == nullptr) continue; sm.update(0); if (sm.updated("liveCalibration")) { auto calib_msg = sm["liveCalibration"].getLiveCalibration().getRpyCalib(); for (int i = 0; i < CALIB_LEN; i++) { calib[i] = calib_msg[i]; } } double t1 = millis_since_boot(); DMonitoringResult res = dmonitoring_eval_frame(&model, buf->addr, buf->width, buf->height, calib); double t2 = millis_since_boot(); // send dm packet dmonitoring_publish(pm, extra.frame_id, res, (t2 - t1) / 1000.0, model.output); //printf("dmonitoring process: %.2fms, from last %.2fms\n", t2 - t1, t1 - last); last = t1; } } int main(int argc, char **argv) { setpriority(PRIO_PROCESS, 0, -15); // init the models DMonitoringModelState model; dmonitoring_init(&model); VisionIpcClient vipc_client = VisionIpcClient("camerad", VISION_STREAM_DRIVER, true); while (!do_exit && !vipc_client.connect(false)) { util::sleep_for(100); } // run the models if (vipc_client.connected) { LOGW("connected with buffer size: %d", vipc_client.buffers[0].len); run_model(model, vipc_client); } dmonitoring_free(&model); return 0; }