#include "app/app.h" #include "bsp/bsp.h" #include "os/os_task.h" #include "libs/logger.h" #include "libs/utils.h" #include "foc/motor/motor.h" #include "foc/motor/current.h" #include "foc/core/foc_observer.h" #include "foc/samples.h" #include "prot/can_foc_msg.h" #include "prot/can_message.h" #include "libs/time_measure.h" #include "app/nv_storage.h" #include "foc/commands.h" #include "bsp/adc.h" #ifdef CONFIG_DQ_STEP_RESPONSE extern float target_d; extern float target_q; #endif static u32 _app_low_task(void *args); static u32 _app_report_task(void *args); static u32 _app_plot_task(void *args); extern void PMSM_FOC_LogDebug(void); extern void err_code_log(void); extern void encoder_log(void); extern measure_time_t g_meas_hall; extern measure_time_t g_meas_foc; extern measure_time_t g_meas_MCTask; #ifdef JTAG_DEBUG int jtag_cmd = 0; int jtag_data = 0; int jtag_plot = 0; void fetch_jtag_cmd(void) { foc_cmd_body_t foc_cmd; if (jtag_cmd == 1 || jtag_cmd == 2) { jtag_plot = 2; foc_cmd.cmd = Foc_Start_Motor; foc_cmd.data = (void *)os_alloc(4); encode_u8(foc_cmd.data, jtag_cmd); foc_send_command(&foc_cmd); jtag_cmd = 0; }else if (jtag_cmd == 3) { float vq = (float)jtag_data/10.0f; PMSM_FOC_SetOpenVdq(0, (vq)); jtag_cmd = 0; }else if (jtag_cmd == 4) { jtag_plot = 1; foc_cmd.cmd = Foc_Cali_Hall_Phase; foc_cmd.data = (void *)os_alloc(4);; encode_s16(foc_cmd.data, jtag_data); foc_send_command(&foc_cmd); jtag_cmd = 0; }else if (jtag_cmd == 5) { PMSM_FOC_Set_Torque((float)jtag_data/10.0f); jtag_cmd = 0; }else if (jtag_cmd == 6) { PMSM_FOC_EnableCruise(true); }else if (jtag_cmd == 7) { PMSM_FOC_EnableCruise(false); }else if (jtag_cmd == 8) { //mc_current_sensor_calibrate((float)jtag_data/10.0f); jtag_cmd = 0; }else if (jtag_cmd == 9) { mc_encoder_zero_calibrate(jtag_data); jtag_cmd = 0; } jtag_cmd = 0; } #else void fetch_jtag_cmd(void){ } #endif void app_start(void){ set_log_level(MOD_SYSTEM, L_debug); can_message_init(); nv_storage_init(); mc_init(); #ifdef GD32_FOC_DEMO extern void key_init(void); key_init(); #endif gpio_led1_enable(true); shark_task_create(_app_low_task, NULL); shark_task_create(_app_report_task, NULL); shark_task_create(_app_plot_task, NULL); sys_debug("mc start\n"); shark_task_run(); } static u32 _app_report_task(void *p) { static u32 loop = 0; can_report_power(0x45); can_report_dq_current(0x45); can_report_foc_status(0x45); can_report_phase_voltage(0x45); can_report_mpta_values(0x45); can_report_ext_status(0x43); can_report_phase_current(0x45); if (++loop % 10 == 0) { //sys_debug("modulation %f, %f\n", PMSM_FOC_Get()->out.f_vdqRation, PMSM_FOC_Get()->rtLim.rpmLimRamp.interpolation); sys_debug("Slow: %d - %d\n", g_meas_MCTask.intval_time, g_meas_MCTask.exec_time); sys_debug("Fast: %d - %d, err: %d-%d-%d\n", g_meas_foc.intval_time, g_meas_foc.exec_time, g_meas_foc.intval_hi_err, g_meas_foc.intval_low_err, g_meas_foc.exec_max_error_time); sys_debug("FOC time err %d %d\n", g_meas_foc.intval_time_h_error, g_meas_foc.intval_time_l_error); sys_debug("acc vol %d, mos2 %d\n", get_acc_vol(), get_mos_temp2()); sys_debug("throttle %f\n", get_throttle_float()); sys_debug("ADC Vref %f, %f\n", get_adc_vref(), adc_5vref_compesion()); sys_debug("target current %f\n", PMSM_FOC_Get()->in.s_targetCurrent); //sys_debug("fan rpm %d, %d\n", mc_params()->fan[0].rpm, mc_params()->fan[1].rpm); encoder_log(); PMSM_FOC_LogDebug(); //err_code_log(); } return 200; } static int plot_type = 1; static void plot_smo_angle(void) { float smo_angle = foc_observer_smo_angle(); float delta = smo_angle - PMSM_FOC_Get()->in.s_hallAngle; if (delta > 180) { delta -= 360; }else if (delta < -180) { delta += 360; } can_plot3(PMSM_FOC_Get()->in.s_hallAngle, smo_angle, delta); } static u32 _app_plot_task(void * args) { if (plot_type == 1) { can_plot2((s16)(PMSM_FOC_Get()->in.s_targetTorque*100.0f), (s16)PMSM_FOC_GetSpeed()); //can_plot3((s16)PMSM_FOC_Get()->vel_lim_adrc.z1, (s16)PMSM_FOC_Get()->vel_lim_adrc.z2, (s16)PMSM_FOC_GetSpeed()); }else if (plot_type == 2) { can_plot2(eCtrl_get_RefTorque(), PMSM_FOC_Get_Real_Torque()); }else if (plot_type == 3) { //can_plot2(PMSM_FOC_GetSpeed(), foc_observer_smo_speed()); plot_smo_angle(); }else if (plot_type == 4) { can_plot2(eCtrl_get_RefTorque(), PMSM_FOC_Get()->in.s_targetTorque); }else if (plot_type == 5) { #ifdef CONFIG_DQ_STEP_RESPONSE can_plot2((s16)(target_d*10.0f), (s16)(PMSM_FOC_Get()->out.s_RealIdq.d * 10.0f)); #endif }else if (plot_type == 6) { can_plot2((s16)(PMSM_FOC_Get()->in.s_iABC[0]), (s16)(PMSM_FOC_Get()->in.s_iABC[1])); }else if (plot_type == 7) { can_plot2((s16)PMSM_FOC_Get()->out.s_FilterIdq.d, (s16)PMSM_FOC_Get()->out.s_FilterIdq.q); } return 20; } static u32 _app_low_task(void *args) { wdog_reload(); fetch_jtag_cmd(); return 1; }