-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathGetPareto_dissertation.m
71 lines (62 loc) · 2.61 KB
/
GetPareto_dissertation.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
% script for running the optim.m program
% clear all
% define which movement we are working on
movement = 'Winter/Winter_normal';
% general settings
problem.Solver = 'IPOPT';
problem.MaxIterations = 10000;
problem.ConstraintTol = .01;
problem.Tol = .0001;
problem.symmetry = 1;
problem.discretization = 'BE'; % start with backward Euler
problem.checkderivatives = 0; % set this to 1 to make optim.m check derivatives
problem.debug = 0; % only used in debug mode
problem.N = 60; % start with a coarse mesh
problem.Printinterval = 10;
% define an able-bodied model and the target gait data for the simulation
ablemodel.parameterfile = 'gait2d_par.xls';
ablemodel.type = 'able';
ablemodel.datafile = movement;
ablemodel.Wtrack = 1; % weight of tracking term in optimization objective
ablemodel.Weffort = 10; % weight of muscle effort term in optimization objective
ablemodel.effort.fatigue = 0;
ablemodel.effort.Fmaxweighted = 0;
ablemodel.effort.exponent = 2;
ablemodel.Wvalve = 0.001; % weight of valve operating cost in optimization objective
ablemodel.discretization = 'euler';
ablemodel.reducedW = 0;
ablemodel.kneeconstraint = 1;
ablemodel.hipconstraint = 1;
% define a below knee amputee model, based on the able-bodied model
bkamodel = ablemodel;
bkamodel.type = 'bka';
% 450 Nm/rad foot stiffness in able bodied subjects (Hansen et al., J Biomech 37: 1467–1474, 2004)
bkamodel.anklestiffness = 600; % stiffness (Nm/rad) of prosthetic ankle
bkamodel.ankledamping = 15; % damping (Nm/rad/s) of prosthetic ankle
bkamodel.Weffort = 10;
bkamodel.Wtrack = 1;
problem.model = bkamodel;
MomAsymBound = [0.091 0.101 0.201];% [5e-4 1e-3 5e-3:5e-3:5e-2 6e-2 7e-2 8e-2 9e-2 1e-1 0.2:0.2:1 1.5:0.5:3];%3 4 5 10 15 20];
bkamodel.Wtrack = 1;
bkamodel.Weffort = 10*bkamodel.Wtrack;
for j = 1:length(MomAsymBound)
bkamodel.Wmom = MomAsymBound(j);
problem.model = bkamodel;
problem.initialguess = 'Winter/Paper/Winter_normal_result_able';
problem.resultfile = ['Winter/Dissertation_MOO/Result_mom1_', num2str(bkamodel.Wmom), '.mat'];
if ~exist(problem.resultfile,'file')
optim_mominconstraint(problem);
else
disp('Already Solved')
end
end
%
% bkamodel.Wmom = 1;
% for j = 1:9
% bkamodel.Wtrack = j/10;
% bkamodel.Weffort = 10*bkamodel.Wtrack;
% problem.model = bkamodel;
% problem.initialguess = 'Winter/Paper/Winter_normal_result_able';
% problem.resultfile = ['Winter/Paper/Result_mom_', num2str(bkamodel.Wmom), '_effort_', num2str(bkamodel.Weffort), '_track_' num2str(bkamodel.Wtrack), '.mat'];
% optim_threeobj(problem);
% end