forked from shooter64738/grbl-mega
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbacklash.c
73 lines (65 loc) · 2.22 KB
/
backlash.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
#include <string.h>
//#include "backlash.h"
#include "grbl.h"
/*
* backlash.c
*
* Author: Jeff Dill
*/
s_back_lash back_lash_compensation;
void backlash_initialize()
{
//memset(back_lash_compensation.new_comp_direction,0,sizeof(back_lash_compensation.new_comp_direction));
memset(back_lash_compensation.last_comp_direction,0,sizeof(back_lash_compensation.last_comp_direction));
memset(back_lash_compensation.comp_per_axis_mm,0,sizeof(back_lash_compensation.comp_per_axis_mm));
}
void backlash_comp(float *target, plan_line_data_t *pl_data)
{
int32_t target_steps[N_AXIS];
int32_t *position_steps;
if (pl_data->condition & PL_COND_FLAG_SYSTEM_MOTION)
{
#ifdef COREXY
position_steps[X_AXIS] = system_convert_corexy_to_x_axis_steps(sys_position);
position_steps[Y_AXIS] = system_convert_corexy_to_y_axis_steps(sys_position);
position_steps[Z_AXIS] = sys_position[Z_AXIS];
#else
memcpy(position_steps, sys_position, sizeof(sys_position));
#endif
}
else
{
position_steps = plan_get_position();
}
uint8_t idx=0;
uint8_t needs_comp = 0;
//printString("checking comp loop\r");
for (idx = 0;idx<N_AXIS;idx++)
{
//Must clear this or the next time we do a comp move we will still have any prior axis comps in there!
back_lash_compensation.comp_per_axis_mm[idx] = 0;// target[idx];
target_steps[idx] = lround(target[idx] * settings.steps_per_mm[idx]);
int32_t step_diff=(target_steps[idx] - position_steps[idx]);
step_diff = step_diff>0?1:(step_diff<0?-1:0);
if (back_lash_compensation.last_comp_direction[idx]!=0 && step_diff!=0
&& (back_lash_compensation.last_comp_direction[idx] !=step_diff))
{
//printString("axis ");
//printInteger(idx);
//printString(" set for comp");
back_lash_compensation.comp_per_axis_mm[idx] = settings.backlash_per_axis[idx]*step_diff;
needs_comp = 1;
}
}
if (needs_comp)
{
float new_target[N_AXIS];
memcpy(new_target,back_lash_compensation.comp_per_axis_mm,sizeof(back_lash_compensation.comp_per_axis_mm));
plan_line_data_t new_plan;
plan_line_data_t *new_pl = &new_plan;
memcpy(new_pl,pl_data,sizeof(plan_line_data_t));
new_plan.condition=(1<<PL_COND_FLAG_BACKLASH_COMP);
new_plan.condition |= PL_COND_FLAG_RAPID_MOTION;
mc_line(new_target,&new_plan);
}
}