Skip to content

Commit

Permalink
Merge branch 'master' of https://github.com/RobotLocomotion/drake
Browse files Browse the repository at this point in the history
  • Loading branch information
RussTedrake committed Nov 15, 2014
2 parents f4e562c + ab5ca36 commit bc7b624
Show file tree
Hide file tree
Showing 386 changed files with 330,442 additions and 6,141 deletions.
5 changes: 1 addition & 4 deletions addpath_drake.m
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,6 @@
addpath(fullfile(root,'solvers'));
addpath(fullfile(root,'solvers','trajectoryOptimization'));
addpath(fullfile(root,'util'));
addpath(fullfile(root,'util','obstacles'));
addpath(fullfile(root,'thirdParty'));
addpath(fullfile(root,'thirdParty','path'));
addpath(fullfile(root,'thirdParty','spatial'));
Expand Down Expand Up @@ -72,14 +71,12 @@
if checkDependency('simulink')
autosave_options = get_param(0,'AutoSaveOptions');
if autosave_options.SaveOnModelUpdate
warning('Disabling autosave for simulink blocks (to avoid generating a lot of *.mdl.autosave files in your directory. If you aren''t a regular Simulink user and don''t want this disabled, comment out this section in addpath_drake');
warning('Drake:DisablingSimulinkAutosave','Disabling autosave for simulink blocks (to avoid generating a lot of *.mdl.autosave files in your directory. If you aren''t a regular Simulink user and don''t want this disabled, comment out this section in addpath_drake.\nTo disable this warning in the future, add\n warning(''off'',''Drake:DisablingSimulinkAutosave'')\nto your matlab startup.m');
autosave_options.SaveOnModelUpdate = false;
set_param(0,'AutoSaveOptions',autosave_options);
end
end
% todo: try setting this before simulating, then resetting it after the
% simulate?



end
2 changes: 1 addition & 1 deletion cmake
224 changes: 210 additions & 14 deletions doc/drakeURDF.xsd

Large diffs are not rendered by default.

22 changes: 11 additions & 11 deletions examples/Acrobot/AcrobotPlant.m
Original file line number Diff line number Diff line change
Expand Up @@ -100,22 +100,22 @@
tf0 = 4;

N = 21;
traj_opt = DircolTrajectoryOptimization(obj,N,[2 6]);
traj_opt = traj_opt.addStateConstraint(ConstantConstraint(x0),1);
traj_opt = traj_opt.addStateConstraint(ConstantConstraint(xf),N);
traj_opt = traj_opt.addRunningCost(@cost);
traj_opt = traj_opt.addFinalCost(@finalCost);
prog = DircolTrajectoryOptimization(obj,N,[2 6]);
prog = prog.addStateConstraint(ConstantConstraint(x0),1);
prog = prog.addStateConstraint(ConstantConstraint(xf),N);
prog = prog.addRunningCost(@cost);
prog = prog.addFinalCost(@finalCost);

traj_init.x = PPTrajectory(foh([0,tf0],[double(x0),double(xf)]));

info=0;
while (info~=1)
for attempts=1:10
tic
[xtraj,utraj,z,F,info] = traj_opt.solveTraj(tf0,traj_init);
[xtraj,utraj,z,F,info] = prog.solveTraj(tf0,traj_init);
toc
if info==1, break; end
end

function [g,dg] = cost(t,x,u);
function [g,dg] = cost(dt,x,u)
R = 1;
g = sum((R*u).*u,1);
dg = [zeros(1,1+size(x,1)),2*u'*R];
Expand All @@ -130,10 +130,10 @@
g = sum((Q*xerr).*xerr + (R*u).*u,1);

if (nargout>1)
dgdt = 0;
dgddt = 0;
dgdx = 2*xerr'*Q;
dgdu = 2*u'*R;
dg = [dgdt,dgdx,dgdu];
dg = [dgddt,dgdx,dgdu];
end
end

Expand Down
File renamed without changes.
Original file line number Diff line number Diff line change
Expand Up @@ -166,17 +166,14 @@ function draw(obj)
end
end

function con = AddConstraints(obj, con)
% Adds the con.x.c constraint for the ObstacleField to the given
% constraint object.
%
% @param con input constraint object. Must be a structure.
% Other than that, we'll just overwrite con.x.c, so anything
% else will be returned unchanged.
function prog = AddConstraints(obj, prog)
% Adds the non-convex constraints for the ObstacleField to the
% given NonlinearProgram
%
% @retval con Constraint structure with modified con.x.c value.
% @param prog a DirectTrajectoryOptimization
% @retval prog the updated NonlinearProgram

con.x.c = @(x)obj.obstacleConstraint(x);
prog = prog.addStateConstraint(FunctionHandleConstraint(-inf(obj.number_of_obstacles,1),zeros(obj.number_of_obstacles,1),2,@(x)obj.obstacleConstraint(x)),1:prog.N,1:2);
end


Expand Down
34 changes: 17 additions & 17 deletions examples/Airplane2D/runDircol.m
Original file line number Diff line number Diff line change
Expand Up @@ -14,27 +14,26 @@
x0 = double(x0);
xf = double(xf);

con.u.lb = p.umin;
con.u.ub = p.umax;
con.x0.lb = x0;
con.x0.ub = x0;
con.xf.lb = xf;
con.xf.ub = xf;
con.T.lb = 0.1;
con.T.ub = 1;
N = 11;
prog = DircolTrajectoryOptimization(p,N,[0.1 1]);

options.method='dircol';
options.MajorOptimalityTolerance=1e-2;
options.trajectory_cost_fun=@(t,x,u)plotDircolTraj(t,x,u,[1 2]); % for debugging
%options.grad_test = true;
prog = addStateConstraint(prog,ConstantConstraint(x0),1);
prog = addStateConstraint(prog,ConstantConstraint(xf),N);

prog = addRunningCost(prog,@cost);
prog = addFinalCost(prog,@finalCost);

prog = addTrajectoryDisplayFunction(prog,@(dt,x,u)plotDircolTraj(dt,x,u,[1 2]));
%options.MajorOptimalityTolerance=1e-2;

t_init = linspace(0,tf0,N);
info = 0;
while (info~=1)
% generate a random trajectory
utraj0 = PPTrajectory(foh(linspace(0,tf0,11),randn(1,11)));
traj_init.u = setOutputFrame(PPTrajectory(foh(t_init,randn(1,N))),getInputFrame(p));

tic
[utraj,xtraj,info] = trajectoryOptimization(p,@cost,@finalcost,x0,utraj0,con,options);
[xtraj,utraj,~,~,info]=solveTraj(prog,t_init,traj_init);
toc
end

Expand All @@ -45,22 +44,23 @@

end

function [g,dg] = cost(t,x,u)
function [g,dg] = cost(dt,x,u)
R = 0;
g = u'*R*u;
%g = sum((R*u).*u,1);
%dg = [zeros(1,1+size(x,1)),2*u'*R];
dg = zeros(1, 1 + size(x,1) + size(u,1));
end

function [h,dh] = finalcost(t,x)
function [h,dh] = finalCost(t,x)
h = t;
dh = [1,zeros(1,size(x,1))];
end

function [J,dJ]=plotDircolTraj(t,x,u,plotdims)
figure(25);
h=plot(x(plotdims(1),:),x(plotdims(2),:),'r.-');
axis([-2 2 -1 10]); axis equal;
drawnow;
delete(h);
J=0;
Expand Down
66 changes: 21 additions & 45 deletions examples/Airplane2D/runDircolWithObs.m
Original file line number Diff line number Diff line change
Expand Up @@ -4,71 +4,46 @@
p = PlanePlant();
end

x0 = [3.9; 0; 0; 0];
tf0 = .7;
x0 = [3.9; 0; 0; 0];
xf = [5; 9; 0; 0];
tf0 = .7;

utraj0 = PPTrajectory(foh(linspace(0,tf0,11),0*randn(1,11)));
utraj0 = setOutputFrame(utraj0,p.getInputFrame);

%con.u.lb = p.umin;
%con.u.ub = p.umax;
con.x0.lb = x0;
con.x0.ub = x0;
con.xf.lb = xf; %[xf(1:2);-inf(2,1)];
con.xf.ub = xf; %[xf(1:2);inf(2,1)];
con.T.lb = .2;
con.T.ub = 3;
N = 21;
prog = DircolTrajectoryOptimization(p,N,[0.2 3]);

prog = addStateConstraint(prog,ConstantConstraint(x0),1);
prog = addStateConstraint(prog,ConstantConstraint(xf),N);

% add obstacles
disp('Adding obstacles...');
field = ObstacleField();
field = field.GenerateRandomObstacles();
con = field.AddConstraints(con);
prog = field.AddConstraints(prog);

prog = addRunningCost(prog,@(dt,x,u)cost(dt,x,u,field));
prog = addFinalCost(prog,@finalCost);

prog = addTrajectoryDisplayFunction(prog,@(dt,x,u)plotDircolTraj(dt,x,u,[1 2]));


figure(25); clf; hold on;
v = PlaneVisualizer(p,field);
v.draw(0,x0);
drawnow

disp('Running trajectory optimization...');

options.method='dircol';
options.MajorOptimalityTolerance=1e-2;
options.trajectory_cost_fun=@(t,x,u)plotDircolTraj(t,x,u,[1 2]); % for debugging
%options.grad_method={'user','taylorvar'};
prog = setSolverOptions(prog,'snopt','MajorOptimalityTolerance',1e-2);
initial_guess.x = PPTrajectory(foh([0,tf0],[x0,xf]));
tic
%options.grad_test = true;
[utraj,xtraj,info] = trajectoryOptimization(p,@(t,x,u)cost(t,x,u,field),@finalcost,x0,utraj0,con,options);
if (info~=1) error(['Airplane2D:SNOPT:INFO',num2str(info)],'failed to find a trajectory'); end
[xtraj,utraj,~,~,info]=solveTraj(prog,tf0,initial_guess);
toc

% upsample
ts = linspace(utraj.tspan(1),utraj.tspan(2),41);
options.xtape0='simulate';
utraj0 = PPTrajectory(foh(ts,utraj.eval(ts))); utraj0 = setOutputFrame(utraj0,utraj.getOutputFrame);
[utraj,xtraj,info] = trajectoryOptimization(p,@(t,x,u)cost(t,x,u,field),@finalcost,x0,utraj0,con,options);
if (info~=1) error(['Airplane2D:SNOPT:INFO',num2str(info)],'failed to improve the trajectory'); end

hold off;

if (nargout>0)
return;
if (nargout<1)
v.playback(xtraj);
end

%disp('Stabilizing trajectory...');
c = tvlqr(p,xtraj,utraj,eye(4),1,eye(4));

disp('Visualizing trajectory...');
v.playback(xtraj);
%v.display_dt=0;v.playback_speed=.5; v.playbackAVI(xtraj,'PlaneWithObs');

disp('Done.');

end

function [g,dg] = cost(t,x,u,field)
function [g,dg] = cost(dt,x,u,field)
R = 0.0001;

% minimize the max obstacle constraint
Expand All @@ -83,14 +58,15 @@
%dg = zeros(1, 1 + size(x,1) + size(u,1));
end

function [h,dh] = finalcost(t,x)
function [h,dh] = finalCost(t,x)
h = t;
dh = [1,zeros(1,size(x,1))];
end

function [J,dJ]=plotDircolTraj(t,x,u,plotdims)
figure(25);
h=plot(x(plotdims(1),:),x(plotdims(2),:),'r.-');
axis([-2 2 -1 10]); axis equal;
drawnow;
delete(h);
J=0;
Expand Down
13 changes: 0 additions & 13 deletions examples/Airplane2D/runPassiveWithObstacles.m

This file was deleted.

Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
function testObstacles

close all
tmp = addpathTemporary(fullfile(pwd,'..'));

f = ObstacleField
f = f.GenerateRandomObstacles();
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,7 @@
function testVerticalAndHorizontalObstacles

tmp = addpathTemporary(fullfile(pwd,'..'));

%% Test edge cases for vertical and horizontal obstacle borders
obs = PolygonalObstacle2D([0,0,1,1], [0,1,1,0]);

Expand Down
Loading

0 comments on commit bc7b624

Please sign in to comment.