-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathParameters.m
337 lines (301 loc) · 14.1 KB
/
Parameters.m
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
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
% Parameter Template for 3D Quadruped --> Use ANYmal Parameters
% Sections wrapped by "<--------->" lines are the parameter places
import casadi.*
%==========================================================================
% Optimization Type Set Up
%<---------------------------------------------------------->
% gait_discovery_switch = 1 -> Discover Gait using MINLP
% gait_discovery_switch = 2 -> Fixed Gait Optimization
gait_discovery_switch = 2;
%<---------------------------------------------------------->
%==========================================================================
%==========================================================================
% Retrive Gait Sequence if we choose to have fixed gait optimization
if gait_discovery_switch == 2
% List of Gaits
% 1 -> Lateral Sequence Walk from WikiPedia
% 2 -> Four-Beat Walking from Remy's Group
% 3 -> Walking Trot (Also Called Two-Beat Walking from Remy's Paper)
% 4 -> Running Trot (Trotting with a Flying Phase)
% 5 -> Tolting from Remy's Paper
% 6 -> Pacing
% 7 -> Amble
% 8 -> Canter
% 9 -> Transverse Gallop
% 10 -> Rotary Gallop
% 11 -> Bounding
% 12 -> Half Cheetah Walking D (Mirrored)
% 13 -> Half Cheetah Galloping (Mirrored)
% 14 -> Half Cheetah Walking-S (Mirrored) (6 Phases)
% 15 -> Half Cheetah Buonding-S_H_F_FLY (Mirrored) (6 Phases)
% 16 -> Half Cheetah Buonding-S_H_FLY_F (Mirrored) (6 Phases)
% 17 -> Pronking
%UserDefinedGaitNumber = 0;
%Decide the GaitNumber
disp('Manually Define the Gait:')
disp('Gait Library: ');
disp(' 0 -> User Input');
disp(' 1 -> Lateral Sequence Walk from WikiPedia');
disp(' 2 -> Four-Beat Walking from Remy''s Group');
disp(' 3 -> Walking Trot (Also Called Two-Beat Walking from Remy''s Paper)');
disp(' 4 -> Running Trot (Trotting with a Flying Phase)');
disp(' 5 -> Tolting from Remy''s Paper');
disp(' 6 -> Pacing');
disp(' 7 -> Amble');
disp(' 8 -> Canter');
disp(' 9 -> Transverse Gallop');
disp(' 10 -> Rotary Gallop');
disp(' 11 -> Bounding');
disp(' 12 -> Half Cheetah Walking D (Mirrored)');
disp(' 13 -> Half Cheetah Galloping (Mirrored)');
disp(' 14 -> Half Cheetah Walking-S (Mirrored) (6 Phases)');
disp(' 15 -> Half Cheetah Buonding-S_H_F_FLY (Mirrored) (6 Phases)');
disp(' 16 -> Half Cheetah Buonding-S_H_FLY_F (Mirrored) (6 Phases)');
disp(' 17 -> Pronking');
if Eddie_flag == 1 %use Eddie, get setup from environment variable
UserDefinedGaitNumber = str2double(getenv('UserDefinedGaitNumber'));
else
UserDefinedGaitNumber = input('Specify the Gait Number: \n');
end
%Build Gait Sequence
if UserDefinedGaitNumber == 0
Clf = input('Input Contact Sequence for Left Front (LF) Foot (i.e. a column vector):\n');
Clh = input('Input Contact Sequence for Left Hind (LH) Foot (i.e. a column vector):\n');
Crf = input('Input Contact Sequence for Right Front (RF) Foot (i.e. a column vector):\n');
Crh = input('Input Contact Sequence for Right Hind (RH) Foot (i.e. a column vector):\n');
else
%error('Optimiation using gait from pre-defined gait library is not implemented for 2D quadruped')
[Clf,Clh,Crf,Crh,GaitName] = QuadrupedGaitPatternGenerator(UserDefinedGaitNumber);
%[Clf,Clh,Crf,Crh,GaitName] = Gait_Selection(UserDefinedGaitNumber);
end
end
%==========================================================================
%==========================================================================
%<---------------------------------------------------------->
% Inertia Parameters
m = 34.7; %kg
I = [1.06933, 0, 0;...
0, 2.12851, 0;...
0, 0, 2.17389]; %kg m^2
G = 9.80665; %m/s^2
%<---------------------------------------------------------->
%==========================================================================
%==========================================================================
% Kinematics Parameters
%<---------------------------------------------------------->
% Body Size
BodyLength = 0.65;
BodyWidth = 0.435;
BodyHeight = 0.24;
% Default foot position in Local robot frame
DefaultLegLength = 0.19; %default leg length , distance from the default Leg Y to Torso (LOWER BORDER of the TORSO)
%<---------------------------------------------------------->
%<---------------------------------------------------------->
% Morphology Definition:
% Morpho_change_flag = 1-> Yes, Alllow Mophorlogy change
% Morpho_change_flag = 2-> No Morphology change (Default: Half-CHeetah)
Morpho_change_flag = 2;
%<---------------------------------------------------------->
% Define Percentage of Morphology change (how much percentage we move a limb from CoM to the border of the torso)
if Morpho_change_flag == 1 %Allow morphology change
%<---------------------------------------------------------->
Morpho_Percentage = 0; % A Humanoid Model
%<---------------------------------------------------------->
Morpho_Percentage = Morpho_Percentage/100;
else %No morphology change (Default Half_Cheetah)
Morpho_Percentage = 100;
Morpho_Percentage = Morpho_Percentage/100;
end
% Default Foot Positions
% Left Front (lf)
PlfCenter = [Morpho_Percentage*(1/2*BodyLength); 1/2*BodyWidth; -(1/2*BodyHeight + DefaultLegLength)];
% Left Hind (lh)
PlhCenter = [-Morpho_Percentage*(1/2*BodyLength); 1/2*BodyWidth; -(1/2*BodyHeight + DefaultLegLength)];
% Right Front (rf)
PrfCenter = [Morpho_Percentage*(1/2*BodyLength); -1/2*BodyWidth; -(1/2*BodyHeight + DefaultLegLength)];
% Right Hind (rh)
PrhCenter = [-Morpho_Percentage*(1/2*BodyLength); -1/2*BodyWidth; -(1/2*BodyHeight + DefaultLegLength)];
%<---------------------------------------------------------->
% Kinematics Bounding Box Constraint
BoundingBox_Length = 0.3;
BoundingBox_Width = 0.1;
BoundingBox_Height = 0.14;%0.14;
%<---------------------------------------------------------->
%==========================================================================
%==========================================================================
% Environment Information
%<---------------------------------------------------------->
% TerrainType
% TerrainType = 1 -> Flat Terrain (Use this if Terrain Slope = 0);
% TerrainType = 2 -> Slopes
TerrainType = 1;
%<---------------------------------------------------------->
if TerrainType == 1 %Flat Terrain
%Build Terrain Model for flat terrain
terrain_slope_degrees = 0;
terrain_slope_rad = terrain_slope_degrees/180*pi;
terrain_slope = tan(terrain_slope_rad);
elseif TerrainType == 2 %Slope
%<---------------------------------------------------------->
%Spoecify the terrain slope in Degrees (i.e.: -30, -10, 0, 10, 30...)
terrain_slope_degrees = 10;
%<---------------------------------------------------------->
terrain_slope_rad = terrain_slope_degrees/180*pi;
terrain_slope = tan(terrain_slope_rad);
else %Unknown Scenario
error('Unknown Terrain Types')
end
%Other Parameters
if TerrainType == 1 %Flat Terrain
TerrainNorm = [0;0;1];
TerrainTangentX = [1;0;0];
TerrainTangentY = [0;1;0];
elseif TerrainType == 2 % %Slope, rotation is inverse in terms of slope up/down
TerrainNorm = [0;0;1];
TerrainTangentX = [1;0;0];
TerrainTangentY = [0;1;0];
TerrainNorm = ElementaryRotation_Y(-terrain_slope_rad)*TerrainNorm;
TerrainTangentX = ElementaryRotation_Y(-terrain_slope_rad)*TerrainTangentX;
TerrainTangentY = ElementaryRotation_Y(-terrain_slope_rad)*TerrainTangentY;
end
%Build Terrain Model
x_query = SX.sym('x_query', 1);
y_query = SX.sym('y_query', 1);
h_terrain = (-TerrainNorm(1)*x_query - TerrainNorm(2)*y_query)/TerrainNorm(3);
TerrainModel = Function('TerrainModel', {x_query,y_query}, {h_terrain});
%<---------------------------------------------------------->
% Friction Cone
miu = 0.6; %friction coefficient
%<---------------------------------------------------------->
%==========================================================================
%==========================================================================
% Task Specifications
%<---------------------------------------------------------->
% Desired Speed Direction
% SpeedDirection = 1 -> Horizontal (x-axis of the world frame)
% SpeedDirection = 2 -> Tangential to the slope
SpeedDirection = 1;
% Specify the MINIMUM Desired Speed along the Desired Direction (m/s)
MinSpeed = 0.3;
% Specify the MAXIMUM Desired Speed along the Desired Direction (m/s)
MaxSpeed = 0.3;
% Specify the Resolution for Scanning the Previously Defined Speed Range (e.g. 0.1, 0.05, 0.02, etc.)
SpeedResolution = 0.2;
%<---------------------------------------------------------->
SpeedList = MinSpeed:SpeedResolution:MaxSpeed;
% Time Step and Discretization Parameter Settings
% Number of Phases
if gait_discovery_switch == 1 %Free Gait Optimization
%<---------------------------------------------------------->
NumPhases = 4;
%<---------------------------------------------------------->
elseif gait_discovery_switch == 2 %Fixed Gait Optimization
%[CF_Sequence, ~, ~] = Gait_Selection(user_defined_gait);
NumPhases = length(Clf);
end
%<---------------------------------------------------------->
% Number of timesteps for each phase
NumLocalKnots = 10;
%<---------------------------------------------------------->
% Setup other dependent paramters
% Total Number of TimeSteps exclude time step 0
NumKnots = NumPhases*NumLocalKnots;
% Parameter tau
tau_upper_limit = 1; %upper limit of tau --> tau \in [0,1]
tauStepLength = tau_upper_limit/NumKnots; %discritization step size of tau
% Discretization of tau
tauSeries = 0:tauStepLength:tau_upper_limit;
tauSeriesLength = length(tauSeries);
%<---------------------------------------------------------->
% Phase Lower Bound setup
% phaselb_type:
% 1 -> Defined as *Percentage* of Total Duration
% 2 -> Defined as a fixed Value
phaselb_type = 1;
if phaselb_type == 1 %Using Percentage of Total Duration (x%)
phase_lower_bound_portion = 10;
phase_lower_bound_portion = phase_lower_bound_portion/100;
%Phaselb = phase_lower_bound_portion*Tend;
elseif phaselb_type == 2 %Using Percentage of Total Duration (i.e. 0.025s, 0.05s)
Phaselb = 0.025;
end
%<---------------------------------------------------------->
%==========================================================================
%==========================================================================
% Big-M Parameters for Complementarity Constraints
%<---------------------------------------------------------->
% Big-M for foot positions in y-axis (meters)
M_pos = 100;
% Big-M for feet velocities
Mvel = 100;
%<---------------------------------------------------------->
% Velocity Boundary (Abusolute Value) for Foot/End-Effector Velocity in X-axis (In Robot Frame)
Vmax = [0;0;0];
%<---------------------------------------------------------->
% Decide Velocity Boundary (Abusolute Value) for Foot/End-Effector in Robot frame in X-axis (In Robot Frame)
Vmax(1) = 0.5;
% Decide Velocity Boundary (Abusolute Value) for Foot/End-Effector in Robot frame in Y-axis (In Robot Frame)
Vmax(2) = 0.5;
% Decide Velocity Boundary (Abusolute Value) for Foot/End-Effector in Robot frame in Z-axis (In Robot Frame)
Vmax(3) = 0.5;
%<---------------------------------------------------------->
% Big-M/Boundaries for Foot-Ground Reaction Forces
Mf = [0;0;0];
%<---------------------------------------------------------->
%Big-M/Boundaries for Foot-Ground Reaction Forces along X-axis (in World Frame)
Mf(1) = 250;
%Big-M/Boundaries for Foot-Ground Reaction Forces along Y-axis (in World Frame)
Mf(2) = 250;
%Big-M/Boundaries for Foot-Ground Reaction Forces along Z-axis (in World Frame)
Mf(3) = 250;
%<---------------------------------------------------------->
%==========================================================================
%==========================================================================
% Cost Function
%<---------------------------------------------------------->
% cost_flag = 1 -> Minimize Force Squared
% cost_flag = 2 -> Minimize Body Vibration, Force Squared and Lateral Limb deviation
% cost_flag = 3 -> Minimize Body Vibration
% cost_flag = 4 -> Smooth Force Profile
% cost_flag = 5 -> Miniimze Body Vibration and Limb Lateral Placement
% [Not Implemented]cost_flag = 6 -> Feet Velocity
% [Not Implemented]cost_flag = 7 -> Humanoid Smooth Motion
cost_flag = 2;
%<---------------------------------------------------------->
%==========================================================================
%==========================================================================
% Solver SetUp
%<---------------------------------------------------------->
% Choose Solver
% SolverNum = 1 -> Knitro
% SolverNum = 2 -> Bonmin
SolverNum = 1;
%<---------------------------------------------------------->
if SolverNum == 1
SolverSelected = 'knitro';
elseif SolverNum == 2
SolverSelected = 'bonmin';
end
%<---------------------------------------------------------->
% Solver Dependent Options
% Define maximum nodes to be explored
% NumMaxNodesCases = 1--> Worst Case Scenario
% NumMaxNodesCases = 2 --> User Specified
% NumMaxNodesCases = 3 --> Default Value
NumMaxNodesCases = 1;
%<---------------------------------------------------------->
if NumMaxNodesCases == 1 %Worst-case Scenario
NumMaxNodes = (2^4)^(NumPhases+1);
elseif NumMaxNodesCases == 2 %User-specified
NumMaxNodes = 1000;
elseif NumMaxNodesCases == 3 %Default Value
NumMaxNodes = 1e5;
else
error('Unexpected Settings of Max Number of Nodes');
end
%<---------------------------------------------------------->
% Define number of multistart solves for each sub-nonlinear
% optimizaiton problem, (i.e. 1, 10, 25, 50, 100)
NumofRuns = 10;
%<---------------------------------------------------------->
%==========================================================================