STM32 双轮差速里程计计算
STM32 双轮差速里程计计算
ODOMETER_EST_PULSE_PER_METER 表示每米距离需要的脉冲数目,参考电机里程计属性设置
#define ODOMETER_EST_PULSE_PER_METER 1320 //通常11线
#define ODOMETER_EST_PULSE_PER_METER 1560 //通常13线
R_param 表示两个轮子分别到双轮中心的距离
leftcnt/ rightcnt 表示左轮在固定时间脉冲计数值,前进为正数,后退为负数。
/* * 固定一段时间(10ms or 20ms)调用 */ void odom_cal_trigger(s32 leftcnt, s32 rightcnt) { float dl = 0.0, dr = 0.0; float sinval = 0.0, cosval = 0.0; dl = leftcnt * (1000.f / ODOMETER_EST_PULSE_PER_METER); // mm dr = rightcnt * (1000.f / ODOMETER_EST_PULSE_PER_METER); // mm float d_yaw = (dr - dl) / 2.0f / R_param; //rad float displacement = (dl + dr) / 2.0f; float dx = cos(d_yaw)*displacement; //mm float dy = sin(d_yaw)*displacement; //mm sinval = sin(odom.yaw), cosval = cos(odom.yaw); odom.x += (cosval * dx - sinval * dy)/1000.f; //m odom.y += (sinval * dx + cosval * dy)/1000.f; //m odom.yaw += d_yaw; //rad }
上一篇:
通过多线程提高代码的执行效率例子
下一篇:
嵌入式系统的发展前景和趋势怎么样