-
Notifications
You must be signed in to change notification settings - Fork 1.2k
/
schunk_wsg_simulation.cc
106 lines (89 loc) · 3.87 KB
/
schunk_wsg_simulation.cc
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
/// @file
///
/// Implements a simulation of the Schunk WSG 50 gripper. Like the
/// driver for the physical gripper, this simulation communicates over
/// LCM using the lcmt_schunk_status and lcmt_schunk_command messages.
/// It is intended to be a direct replacement for the Schunk WSG
/// driver.
#include <cmath>
#include <memory>
#include <gflags/gflags.h>
#include "drake/common/drake_assert.h"
#include "drake/examples/schunk_wsg/simulated_schunk_wsg_system.h"
#include "drake/lcmt_schunk_wsg_command.hpp"
#include "drake/lcmt_schunk_wsg_status.hpp"
#include "drake/manipulation/schunk_wsg/schunk_wsg_constants.h"
#include "drake/manipulation/schunk_wsg/schunk_wsg_controller.h"
#include "drake/manipulation/schunk_wsg/schunk_wsg_lcm.h"
#include "drake/multibody/rigid_body_plant/drake_visualizer.h"
#include "drake/multibody/rigid_body_plant/rigid_body_plant.h"
#include "drake/systems/analysis/simulator.h"
#include "drake/systems/framework/diagram.h"
#include "drake/systems/framework/diagram_builder.h"
#include "drake/systems/framework/leaf_system.h"
#include "drake/systems/lcm/lcm_interface_system.h"
#include "drake/systems/lcm/lcm_publisher_system.h"
#include "drake/systems/lcm/lcm_subscriber_system.h"
DEFINE_double(simulation_sec, std::numeric_limits<double>::infinity(),
"Number of seconds to simulate.");
namespace drake {
namespace examples {
namespace schunk_wsg {
namespace {
using manipulation::schunk_wsg::SchunkWsgStatusSender;
using manipulation::schunk_wsg::SchunkWsgController;
using systems::Context;
using systems::Diagram;
using systems::DiagramBuilder;
using systems::DrakeVisualizer;
using systems::RigidBodyPlant;
using systems::Simulator;
int DoMain() {
systems::DiagramBuilder<double> builder;
auto plant = builder.AddSystem(CreateSimulatedSchunkWsgSystem<double>());
const RigidBodyTree<double>& tree = plant->get_rigid_body_tree();
auto lcm = builder.AddSystem<systems::lcm::LcmInterfaceSystem>();
DrakeVisualizer* visualizer =
builder.AddSystem<DrakeVisualizer>(tree, lcm);
visualizer->set_name("visualizer");
auto command_sub = builder.AddSystem(
systems::lcm::LcmSubscriberSystem::Make<lcmt_schunk_wsg_command>(
"SCHUNK_WSG_COMMAND", lcm));
command_sub->set_name("command_subscriber");
auto wsg_controller = builder.AddSystem<SchunkWsgController>();
auto status_pub = builder.AddSystem(
systems::lcm::LcmPublisherSystem::Make<lcmt_schunk_wsg_status>(
"SCHUNK_WSG_STATUS", lcm,
manipulation::schunk_wsg::kSchunkWsgLcmStatusPeriod
/* publish period */));
status_pub->set_name("status_publisher");
auto status_sender = builder.AddSystem<SchunkWsgStatusSender>();
auto mbp_state_to_wsg_state = builder.AddSystem(
manipulation::schunk_wsg::MakeMultibodyStateToWsgStateSystem<double>());
status_sender->set_name("status_sender");
builder.Connect(command_sub->get_output_port(),
wsg_controller->GetInputPort("command_message"));
builder.Connect(wsg_controller->GetOutputPort("force"),
plant->actuator_command_input_port());
builder.Connect(plant->state_output_port(), visualizer->get_input_port(0));
builder.Connect(plant->state_output_port(),
mbp_state_to_wsg_state->get_input_port());
builder.Connect(mbp_state_to_wsg_state->get_output_port(),
status_sender->get_state_input_port());
builder.Connect(plant->state_output_port(),
wsg_controller->GetInputPort("state"));
builder.Connect(*status_sender, *status_pub);
auto sys = builder.Build();
Simulator<double> simulator(*sys);
simulator.Initialize();
simulator.AdvanceTo(FLAGS_simulation_sec);
return 0;
}
} // namespace
} // namespace schunk_wsg
} // namespace examples
} // namespace drake
int main(int argc, char* argv[]) {
gflags::ParseCommandLineFlags(&argc, &argv, true);
return drake::examples::schunk_wsg::DoMain();
}