-
Notifications
You must be signed in to change notification settings - Fork 21
/
Copy pathHexapod_Config_1.h
143 lines (125 loc) · 5.04 KB
/
Hexapod_Config_1.h
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
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
/**
* S T E W A R T P L A T F O R M O N E S P 3 2
*
* Copyright (C) 2019 Nicolas Jeanmonod, ouilogique.com
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*
*/
#pragma once
/*
* ======== SERVO SETTINGS ========
*/
#define NB_SERVOS 6
/*
* Servo calibration values.
* These values should not be used to restrict servo movements.
* Use MIN/MAX COORDINATES below for that.
*/
const double SERVO_FULL_ANGULAR_RANGE = radians(180);
const double SERVO_HALF_ANGULAR_RANGE = SERVO_FULL_ANGULAR_RANGE / 2;
const int SERVO_MIN_PWM = 183;
const int SERVO_MAX_PWM = 467;
/*
* Offset values in µs to compensate for arm angle errors.
*/
const int PW_OFFSET[] = {
0,
0,
0,
0,
0,
0};
/*
* The gain in µs/rad
* Typical gain =~ 318 µs/rad =~ 5.6 µs/°
*/
const double gain = (SERVO_MAX_PWM - SERVO_MIN_PWM) /
(SERVO_FULL_ANGULAR_RANGE);
/*
* calibration_t
*/
typedef struct
{
double gain;
int offset;
} calibration_t;
/*
* Calibration factors. These values take into account the fact
* that the odd and even arms are a reflection of each other.
* The calibration is linear:
* pulse width (µs) = gain (µs/rad) + offset (µs)
*/
const calibration_t SERVO_CALIBRATION[NB_SERVOS] = {
{-gain, SERVO_MAX_PWM + PW_OFFSET[0]},
{gain, SERVO_MIN_PWM + PW_OFFSET[1]},
{-gain, SERVO_MAX_PWM + PW_OFFSET[2]},
{gain, SERVO_MIN_PWM + PW_OFFSET[3]},
{-gain, SERVO_MAX_PWM + PW_OFFSET[4]},
{gain, SERVO_MIN_PWM + PW_OFFSET[5]}};
/*
* ======== GEOMETRY SETTINGS ========
*/
/*
* Orientations of the servos arms relative to the X axis.
*/
const double THETA_S[NB_SERVOS] = {
radians(-60),
radians(120),
radians(180),
radians(0),
radians(60),
radians(-120)};
/*
* MIN/MAX COORDINATES
* NOTE: The actual min and max for each DOF are interdependent. eg:
* If the platform is pitched by some amount, the roll min/max will be physically
* different than what’s defined here. These are just the absolute maximums under
* ideal conditions (eg: max for roll when pitch is zero).
*/
const double HX_X_MIN = -24;
const double HX_X_MAX = 24;
const double HX_X_MID = (HX_X_MAX + HX_X_MIN) / 2;
const double HX_X_BAND = HX_X_MAX - HX_X_MIN;
const double HX_Y_MIN = -24;
const double HX_Y_MAX = 24;
const double HX_Y_MID = (HX_Y_MAX + HX_Y_MIN) / 2;
const double HX_Y_BAND = HX_Y_MAX - HX_Y_MIN;
const double HX_Z_MIN = -12.0;
const double HX_Z_MAX = 12.0;
const double HX_Z_MID = (HX_Z_MAX + HX_Z_MIN) / 2;
const double HX_Z_BAND = HX_Z_MAX - HX_Z_MIN;
const double HX_A_MIN = radians(-12.0);
const double HX_A_MAX = radians(12.0);
const double HX_A_MID = (HX_A_MAX + HX_A_MIN) / 2;
const double HX_A_BAND = HX_A_MAX - HX_A_MIN;
const double HX_B_MIN = radians(-12.0);
const double HX_B_MAX = radians(12.0);
const double HX_B_MID = (HX_B_MAX + HX_B_MIN) / 2;
const double HX_B_BAND = HX_B_MAX - HX_B_MIN;
const double HX_C_MIN = radians(-43.0);
const double HX_C_MAX = radians(43.0);
const double HX_C_MID = (HX_C_MAX + HX_C_MIN) / 2;
const double HX_C_BAND = HX_C_MAX - HX_C_MIN;
const double THETA_P = radians(48.4099); // Platform joint angle (radians) offset from AXIS[1|2|3]. A value of zero puts these joints directly on the axes.
const double THETA_B = radians(22.9492); // Base Servo pinion angle (radians) offset from AXIS[1|2|3]. A value of zero puts the servo pinion directly on the axes.
const double P_RAD = 99.61 / 2; // Platform radius (mm). The distance from the center of the platform to the center of one platform / pushrod "joint". This should be the same for all six pushrods.
const double B_RAD = 153.99 / 2; // Base radius (mm). Distance from the center of the base plate to the center of one servo pinion gear. Again, this should be the same for all six servos.
const double ARM_LENGTH = 15.0; // Servo arm length (mm). Distance from the center of the servo pivot to the center of the pushrod pivot on the servo arm.
const double ROD_LENGTH = 140.0; // Push rod length (mm). Distance between pushrod ball joints (servo to platform).
const double Z_HOME = -132.943591247488; // Default Z height of the platform (above the base), with servo arms horizontal. Formally, the distance from the plane described by the collection of servo pinion gear centers, to the plane described by the collection of platform / pushrod joints. Must Be fine tuned manualy or computed with a numerical solver.
/*
* ======== ALGORITHM FOR SERVO ANGLE CALCULATIONS ========
*/
#define ALGO 3