forked from RussTedrake/underactuated
-
Notifications
You must be signed in to change notification settings - Fork 0
/
drake.html
193 lines (127 loc) · 9.98 KB
/
drake.html
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
<!DOCTYPE html>
<html>
<head>
<title>Underactuated Robotics</title>
<meta name="Underactuated Robotics" content="text/html; charset=utf-8;" />
<script type="text/javascript" src="chapters.js"></script>
<script type="text/javascript" src="htmlbook/book.js"></script>
<script src="htmlbook/mathjax-config.js" defer></script>
<script type="text/javascript" id="MathJax-script" defer
src="https://cdn.jsdelivr.net/npm/mathjax@3/es5/tex-svg.js">
</script>
<link rel="stylesheet" href="htmlbook/highlight/styles/default.css">
<script src="htmlbook/highlight/highlight.pack.js"></script> <!-- http://highlightjs.readthedocs.io/en/latest/css-classes-reference.html#language-names-and-aliases -->
<script>hljs.initHighlightingOnLoad();</script>
<link rel="stylesheet" type="text/css" href="htmlbook/book.css">
</head>
<body onload="loadChapter('underactuated');">
<div data-type="titlepage">
<header>
<h1><a href="underactuated.html" style="text-decoration:none;">Underactuated Robotics</a></h1>
<p data-type="subtitle">Algorithms for Walking, Running, Swimming, Flying, and Manipulation</p>
<p style="font-size: 18px;"><a href="http://people.csail.mit.edu/russt/">Russ Tedrake</a></p>
<p style="font-size: 14px; text-align: right;">
© Russ Tedrake, 2020<br/>
<a href="tocite.html">How to cite these notes</a><br/>
</p>
</header>
</div>
<p><b>Note:</b> These are working notes used for <a
href="http://underactuated.csail.mit.edu/Spring2020/">a course being taught
at MIT</a>. They will be updated throughout the Spring 2020 semester. <a
href="https://www.youtube.com/channel/UChfUOAhz7ynELF-s_1LPpWg">Lecture videos are available on YouTube</a>.</p>
<chapter><h1>Drake</h1>
<p><drake></drake> is the main software toolbox that we use for this text,
which in fact originated in a large part due to the MIT underactuated course.
The <drake></drake> website is the main source for information and
documentation. The goal of this chapter is to provide any additional
information that can help you get up and running with the examples and
exercises provided in these notes.</p>
<section><h1>Pydrake</h1>
<p><drake></drake> is primarily a C++ library, with rigorous coding
standards and a maturity level intended to support even professional
applications in industry. In order to provide a gentler introduction, and
to facilitate rapid prototyping, I've written these notes exclusively in
python, using Drake's python bindings (pydrake). These bindings are less
mature than the C++ backend; your feedback (and even contributions) are very
welcome. It is still improving rapidly.</p>
<p>In particular, while the C++ API documentation is excellent, the autogenerated python docs are still a work in progress. I currently recommend using the <a href="https://drake.mit.edu/doxygen_cxx/">C++ documentation</a> to find what you need, then checking the <a href="https://drake.mit.edu/pydrake/">Python documentation</a> only if you need to understand how the class or method is spelled in pydrake.</p>
<p>There are also a number of <a href="https://nbviewer.jupyter.org/github/RobotLocomotion/drake/tree/master/tutorials/">tutorials</a> in <drake></drake> that can help you get started.</p>
</section>
<section><h1>Online Jupyter Notebooks</h1>
<p>I will provide nearly all examples and exercises in the form of a <a
href="http://jupyter.org/">Jupyter Notebook</a> so that we can leverage the
fantastic and relatively recent availability of (free) cloud resources.
There are a number of examples throughout the text (listed below) which will
help you load the notebooks in the cloud, allowing you to do some
sophisticated computation without installing anything on your machine!
Links to the code will look like this:</p>
<jupyter>examples/double_pendulum/dynamics.ipynb</jupyter>
<p>You'll notice that we provide links to <i>both</i> Google's Colaboratory and Binder, because they both have some advantages and disadvantages.</p>
<p><b>Google's Colaboratory</b> is a fantastic resource, with generous computational resources and a very convenient interface that allows you to save/load your work on Google Drive. The downside of Colab is that we cannot provision the machines ahead of time. We have a slightly ugly install script at the top of every notebook, and the first time you open each notebook it takes about two minutes to provision the machine. At the time of this writing, it seems that the machine will stay provisioned for you <a href="https://stackoverflow.com/questions/54057011/google-colab-session-timeout">for 90 minutes if you close the browser, or 12 hours if you keep it open.</a> Provisioning is per user and appears relatively unlimited.</p>
<p><b>Binder</b> is another great resource, which we can configure to provision directly from a Docker instance. It appears to provision itself by project -- once one of us starts a Binder instance for an example, it should load more quickly for the rest of us. But Binder has some potentially painful limitations -- it seems that <a href="https://mybinder.readthedocs.io/en/latest/faq.html#how-long-will-my-binder-session-last">all modifications to your notebook are lost after 10 minutes of inactivity</a>, and there is a <a href="https://mybinder.readthedocs.io/en/latest/user-guidelines.html#maximum-concurrent-users-for-a-repository">limit on the number of simultaneous users</a>.</p>
<p>As a general rule, I would currently recommend Binder for quick explorations, but strongly recommend Colab if you intend to build on any of the examples or do any of the exercises. Please use Colab if you are taking the course and planning to submit your assignment for credit.</p>
</section>
<section><h1>Running on your own machine</h1>
<p>As you get more advanced, you will want to run (and extend) these examples on your own machine. The <drake></drake> website has a number of <a href="https://drake.mit.edu/installation.html">installation options</a>, including precompiled binaries and Docker instances. Here I provide an example workflow of setting up drake from the precompiled binaries and running the textbook examples.</p>
<p>First, pick your platform (click on your OS):</p>
<p style="text-align:center">
<span class="bionic">
<b>Ubuntu Linux (Bionic)</b> |
<span onclick="setPlatform('mac');" style="text-decoration:underline;cursor:pointer">Mac Homebrew</span>
</span>
<span class="mac">
<span onclick="setPlatform('bionic');"
style="text-decoration:underline;cursor:pointer">Ubuntu Linux
(Bionic)</span> |
<b>Mac Homebrew</b> </span></p>
<subsection><h1>Install Drake</h1>
<p>The links below indicate the specific distributions that the
examples in this text have been tested against.</p>
<h4 >Download the binaries</h4>
<div class="bionic"><pre class="highlight"><code>curl -o drake.tar.gz <div id="drake-bionic-binaries" style="display:inline">https://drake-packages.csail.mit.edu/drake/nightly/drake-latest-bionic.tar.gz</div></code></pre></div>
<div class="mac"><pre class="highlight"><code>curl -o drake.tar.gz <div id="drake-mac-binaries" style="display:inline">https://drake-packages.csail.mit.edu/drake/nightly/drake-latest-mac.tar.gz</div></code></pre></div>
<h4>Unpack and set your PYTHONPATH and Test</h4>
<div class="bionic"><pre class="highlight"><code>sudo tar -xvzf drake.tar.gz -C /opt
sudo /opt/drake/share/drake/setup/install_prereqs
export PYTHONPATH=/opt/drake/lib/python3.6/site-packages:${PYTHONPATH}
python3 -c 'import pydrake; print(pydrake.__file__)</code></pre></div>
<div class="mac"><pre class="highlight"><code>sudo tar -xvzf drake.tar.gz -C /opt
/opt/drake/share/drake/setup/install_prereqs
export PYTHONPATH=/opt/drake/lib/python3.7/site-packages:${PYTHONPATH}
export PATH=/usr/local/opt/python/libexec/bin:${PATH}
python3 -c 'import pydrake; print(pydrake.__file__)</code></pre></div>
</section>
<subsection><h1>Download the textbook supplement</h1>
<div><pre class="highlight"><code>git clone https://github.com/RussTedrake/underactuated.git</code></pre></div>
<p>and install the prerequisites using the platform-specific installation script provided:</p>
<div class="bionic"><pre class="highlight"><code>sudo underactuated/scripts/setup/ubuntu/18.04/install_prereqs
export PYTHONPATH=`pwd`/underactuated:${PYTHONPATH}</code></pre></div>
<div class="mac"><pre class="highlight"><code>underactuated/scripts/setup/mac/install_prereqs
export PYTHONPATH=`pwd`/underactuated:${PYTHONPATH}</code></pre></div>
</subsection>
<subsection><h1>Run Jupyter Notebook</h1>
<div><pre class="highlight"><code>cd underactuated
jupyter notebook
</code></pre></div>
<p>Most of the examples are in the <code>underactuated</code> subdirectory. You might try running <code>underactuated/double_pendulum/dynamics.ipynb</code> to get started. Have fun!</p>
</subsection>
</section>
<section><h1>Getting help</h1>
<p>If you have trouble with <drake></drake>, please follow the advice <a href="https://drake.mit.edu/getting_help.html">here</a>. If you have trouble with the underactuated repo, you can check for known issues (and potentially file a new one) <a href="https://github.com/RussTedrake/underactuated/issues">here</a>.</p>
</section>
<div style="height:30px"></div>
<section><h1>Listing of <drake></drake> examples throughout this text</h1>
<p>The best overview we have for the remaining capabilities in <drake></drake> are the main chapters of these notes. For convenience, here is a list of software examples that are sprinkled throughout the text:</p>
<div id="list_of_drake_examples"><center>Coming soon!</center></div>
</section>
</chapter>
<div id="footer">
<hr>
<table style="width:100%;">
<tr><td><em>Underactuated Robotics</em></td><td align="right">© Russ
Tedrake, 2020</td></tr>
</table>
</div>
</body>
</html>