| 
									
										
										
										
											2018-06-08 19:55:24 -04:00
										 |  |  | #ifndef ITERSOLVE_H
 | 
					
						
							|  |  |  | #define ITERSOLVE_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-27 13:23:03 -04:00
										 |  |  | #include <stdint.h> // int32_t
 | 
					
						
							| 
									
										
										
										
											2018-06-08 19:55:24 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-27 21:05:57 -04:00
										 |  |  | enum { | 
					
						
							|  |  |  |     AF_X = 1 << 0, AF_Y = 1 << 1, AF_Z = 1 <<2, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-08 19:55:24 -04:00
										 |  |  | struct stepper_kinematics; | 
					
						
							| 
									
										
										
										
											2019-10-27 13:23:03 -04:00
										 |  |  | struct move; | 
					
						
							| 
									
										
										
										
											2019-10-27 11:06:46 -04:00
										 |  |  | typedef double (*sk_calc_callback)(struct stepper_kinematics *sk, struct move *m | 
					
						
							|  |  |  |                                    , double move_time); | 
					
						
							| 
									
										
										
										
											2019-10-27 11:14:40 -04:00
										 |  |  | typedef void (*sk_post_callback)(struct stepper_kinematics *sk); | 
					
						
							| 
									
										
										
										
											2018-06-08 19:55:24 -04:00
										 |  |  | struct stepper_kinematics { | 
					
						
							|  |  |  |     double step_dist, commanded_pos; | 
					
						
							|  |  |  |     struct stepcompress *sc; | 
					
						
							| 
									
										
										
										
											2019-10-27 21:05:57 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     double last_flush_time; | 
					
						
							|  |  |  |     struct trapq *tq; | 
					
						
							|  |  |  |     int active_flags; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-27 11:06:46 -04:00
										 |  |  |     sk_calc_callback calc_position_cb; | 
					
						
							| 
									
										
										
										
											2019-10-27 11:14:40 -04:00
										 |  |  |     sk_post_callback post_cb; | 
					
						
							| 
									
										
										
										
											2018-06-08 19:55:24 -04:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-27 21:05:57 -04:00
										 |  |  | int32_t itersolve_generate_steps(struct stepper_kinematics *sk | 
					
						
							|  |  |  |                                  , double flush_time); | 
					
						
							|  |  |  | double itersolve_check_active(struct stepper_kinematics *sk, double flush_time); | 
					
						
							|  |  |  | void itersolve_set_trapq(struct stepper_kinematics *sk, struct trapq *tq); | 
					
						
							| 
									
										
										
										
											2018-06-08 19:55:24 -04:00
										 |  |  | void itersolve_set_stepcompress(struct stepper_kinematics *sk | 
					
						
							|  |  |  |                                 , struct stepcompress *sc, double step_dist); | 
					
						
							| 
									
										
										
										
											2019-11-13 18:58:51 -05:00
										 |  |  | void itersolve_set_position(struct stepper_kinematics *sk | 
					
						
							|  |  |  |                             , double x, double y, double z); | 
					
						
							| 
									
										
										
										
											2018-06-22 13:03:07 -04:00
										 |  |  | double itersolve_get_commanded_pos(struct stepper_kinematics *sk); | 
					
						
							| 
									
										
										
										
											2018-06-08 19:55:24 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | #endif // itersolve.h
 |