zwischenstand, +makeindex"
[bachelor-thesis/written-stuff.git] / Ausarbeitung / experiment1.tex
index bf488d6..ca605b9 100644 (file)
@@ -1,5 +1,4 @@
 \chapter{Experiment 1: Original Movement Behaviour}
-\todo{}
 \section{Setup}
 
 \begin{figure}[htbp]
  \caption{Measuring turn angles with laser pointer\label{fig:laserpointer}}
 \end{figure}
 
-The test equipment consisted of a small Intel Atom netbook which was mounted on
-an iRobot Roomba~500 robot. The netbook controlled the Roomba over a
-\acs{USB}-to-serial converter plugged into the Open Interface port on the
-Roomba, and hosted as the environment for executing the Wiselib code (see
-fig.~\ref{fig:roombasetup}).
+The test equipment consisted of a small Intel Atom \index{netbook} which was
+mounted on
+an iRobot Roomba~500\index{Roomba~500} robot. The netbook controlled the Roomba
+over a
+\acs{USB}-to-serial converter plugged into the Open Interface \index{Open
+Interface|see {iRobot Roomba Open Interface}} port on the
+Roomba, and hosted as the environment for executing the Wiselib \index{Wiselib}
+code (see fig.~\ref{fig:roombasetup}).
 
 In the first experiment, the original movement behaviour of the Roomba was
 measured to establish a pool of data for correction approaches to work on.
 There was no error correction involved, and the Roomba started right off with
 the full velocity the movement was executed with; so there was no control to
-adhere a constant acceleration when starting or stopping the movement.
+adhere a constant acceleration when starting or stopping the movement. Due to
+limitations in the iRobot Roomba Open Interface\index{Open Interface} it is only
+possible to explicitly start and stop the Roomba's movements at different times,
+so the Wiselib's implementation of the Roomba control code first starts the
+Roomba's movement, calculates the time needed until the movement should be
+finished, and then stops the Roomba.
 
 The tests were done in two atomic drive modes: letting the Roomba drive a
 specific straight distance with a specific velocity in its viewing direction and
 letting it turn on the spot with a specific velocity about a specific angle.
-Each of the two modes was carried out on two different floor types, a laminated
-floor and a carpet floor, to see if the movement behaviour significantly
-depended on the floor type.
+Each of the two modes was carried out on two different floor types\index{floor
+type}, a laminated floor and a carpet floor, to see if the movement behaviour
+significantly depended on the floor type.
 
 The actual travelled distance of the straight drive tests were determined using
 a measuring tape with an accuracy of 1~mm. Only the distance in the Roomba's
@@ -42,11 +49,11 @@ The actual turn angles of the turn tests were determined using a DIN~A0 sheet
 of paper with a printed polar coordinate system in which a circular hole was cut
 in the center to let the Roomba's wheels touch the floor. The sheet was fixed
 on the floor, and the Roomba was aligned in the center of the paper. A laser
-pointer attached to the Roomba pointed to the current orientation on the paper,
-as shown in fig.~\ref{fig:laserpointer}. The accuracy for these tests was
-1~degree.
+pointer\index{laser pointer} attached to the Roomba pointed to the current
+orientation on the paper, as shown in fig.~\ref{fig:laserpointer}. The accuracy
+for these tests was 1~degree.
 
-After the initial setup, the application \definition{\cmd{roomba\_tests}} (see
+After the initial setup, the application \cmd{roomba\_tests} (see
 section~\ref{sec:impl:measuring}) was started on the netbook for half-automatic
 testing. It used a predefined array of nominal distances, angles and velocities
 and for each pair of distance (for straight drive tests) or angle (for turn
@@ -55,7 +62,8 @@ it asked the user to input the measured distance or angle the Roomba had moved
 and repeated the process until each combination of distance/angle and velocity
 was used. The nominal and input values were written to a log file, as well as
 the floor type, the Roomba ID, the \ac{SVN} revision the program was built
-from, the battery status, and other internal implementation-specific values.
+from, the battery status\index{battery status}, and other internal
+implementation-specific values.
 
 For the straight drive tests, the arrays with predefined values were:\\
 \begin{tabular}[h!]{ll}
@@ -68,37 +76,42 @@ For the turn tests, the arrays with predefined values were:\\
   Turn angles: & 5, 15, 30, 45, 90, 120, 180, 360, 530, and 720~degree \\
   Velocities: & 20, 50, 70, 100, 150, 200, 300, and 400~mm/s \\
 \end{tabular}
-According to the implementation of the Wiselib Roomba control, the velocities
-were given in mm/sec and referred to the distance the wheels travelled when
-the Roomba turned on the spot, which was a circle of 230~mm in diameter.
+According to the implementation of the Wiselib Roomba control,
+the velocities were given in mm/sec and referred to the distance the wheels
+travelled when the Roomba turned on the spot, which was a circle of 230~mm in
+diameter.
 
 
 \section{Results}
-
+\label{exp1:results}
 The following graphs show the difference from the measured value to the input
 value for driving or turning with different velocities. Positive values mean
 that the Roomba had turned too much or travelled more than the target value,
-negative values mean that the Roomba had turned or travelled less.
+negative values mean that the Roomba had turned or travelled too less. The
+plots show multiple test runs; given are the minimum, the maximum and the
+arithmetic mean\index{arithmetic mean} of all results for a data point.
 
-\begin{figure}[pt!]
+\todo{clearpage, cleardoublepage?}
+%\clearpage
+\begin{figure}[p!]
  \centering
  \includegraphics[width=\textwidth]{images/iz250flur_drive_data.pdf}
  \caption{Original behaviour on laminated floor, straight drive tests
   \label{fig:orig:lam:drive}}
 \end{figure}
-\begin{figure}[pb!]
+\begin{figure}[p!]
  \centering
  \includegraphics[width=\textwidth]{images/iz250flur_turn_data.pdf}
  \caption{Original behaviour on laminated floor, turn tests
   \label{fig:orig:lam:turn}}
 \end{figure}
-\begin{figure}[pt!]
+\begin{figure}[p!]
  \centering
  \includegraphics[width=\textwidth]{images/seminarraum_drive_data.pdf}
  \caption{Original behaviour on carpet floor, straight drive tests
   \label{fig:orig:carpet:drive}}
 \end{figure}
-\begin{figure}[pb!]
+\begin{figure}[p!]
  \centering
  \includegraphics[width=\textwidth]{images/seminarraum_turn_data.pdf}
  \caption{Original behaviour on carpet floor, straight drive tests
@@ -111,9 +124,17 @@ laminated floor, however, in fig.~\ref{fig:orig:carpet:drive} we see the
 opposite effect on the carpet floor, the error decreases with greater input
 distance. This could happen due to imprecise measurement of distances in either
 the Roomba's sensors or the Wiselib implementation that controls the Roomba, or
-both. Also slippage of the wheels on the laminated floor could be possible,
-explaining the descending
+both, adding up over the time the movement continues. Also slippage of the
+wheels on the laminated floor could be possible, as well as slowdown through
+the carpet floor, explaining why the error increases on the laminated floor, but
+decreases into negative values on the carpet floor when the distance grows.
+
 On the other hand, rising the velocity always seems to cause the
 error to increase.
 
+The same effects also apply for turn tests. Additionally, there could be errors
+resulting from false assumptions about the Roomba's wheelbase\index{wheelbase}
+diameter, resulting in false calculations of the circle the Roomba's wheels
+describe while turning, and therefore leading to false results.
+
 \todo{statistical values, stddev?}
This page took 0.026452 seconds and 4 git commands to generate.