fixed baraomter issue (skip first few readings due to sensor errors)
added new eval using shortest-path + plotting removed compiler warnings for clean-code fixed some minor issues added new TeX code and new graphics
This commit is contained in:
@@ -21,3 +21,6 @@
|
||||
mit pfad laeuft es falsch, weil die andere treppe kuerzer zum ziel ist und das wlan dort besser passt}
|
||||
|
||||
\commentByFrank{zu grosser einfluss vom pfad ist also kein allheilmittel.. kann, wie beim treppenhaus, auch nach hinten los gehen}
|
||||
|
||||
|
||||
\commentByFrank{path1: bad start due to nearby AP and bad parameters (path-loss too high)}
|
||||
|
||||
@@ -12,3 +12,9 @@
|
||||
\subsection{Weighting}
|
||||
|
||||
\subsection{Pathfinding}
|
||||
|
||||
\commentByFrank{describe the multi-path version}
|
||||
|
||||
\commentByFrank{describe the single-path version}
|
||||
\commentByFrank{exp-dist for distance to the path. more distance = less-likely}
|
||||
\commentByFrank{lambda-factor controls the allowed deviation from the shortest-path}
|
||||
|
||||
@@ -6,26 +6,41 @@
|
||||
preferred over absolute ones. However, due to noisy sensors \todo{cite oder grafik? je nach platz}, one
|
||||
single reading is not enough as a relative base. Harnessing the usual setup time of a navigation-system (
|
||||
route calculation, user checking the route) we use the average of all barometer readings during this
|
||||
timeframe as realtive base $\overline{\mPressure}$.
|
||||
timeframe as realtive base $\overline{\mObsPressure}$. However, it is often necessary to omit the first few
|
||||
sensors readings, as the sensor needs some time to settle and the estimated base would otherwise be far off
|
||||
the real values (see fig. \ref{fig:baroSetupError}). Besides, we use the system's setup time to estimate the
|
||||
sensors uncertainty $\sigma_\text{baro}$ for later use within the evaluation.
|
||||
|
||||
During each transition from $\mStateVec_{t-1}$ to $\mStateVec_t$, the predicted pressure $\mStatePressure$ is
|
||||
adjusted according to the resulting $z$-change, if any:
|
||||
\begin{figure}
|
||||
\include{gfx/baro/baro_setup_issue}
|
||||
\caption{Sometimes the barometer provides erroneous \SI{}{\hpa} readings during the first seconds. Those
|
||||
need to be omitted before $\sigma_\text{baro}$ and $\overline{\mObsPressure}$ are estimated.}
|
||||
\label{fig:baroSetupError}
|
||||
\end{figure}
|
||||
|
||||
During each transition from $\mStateVec_{t-1}$ to $\mStateVec_t$, we need a corresponding, relative pressure
|
||||
prediction $\mStatePressure$ which is adjusted according to the resulting $z$-change, if any:
|
||||
|
||||
\begin{equation}
|
||||
\mState_{t}^{\mStatePressure} = \mState_{t-1}^{\mStatePressure} + \Delta z \cdot \SI{0.105}{\hpa}
|
||||
,\enskip
|
||||
\Delta z = \mState_{t-1}^{z} - \mState_{t}^z
|
||||
.
|
||||
\label{eq:baroTransition}
|
||||
\end{equation}
|
||||
|
||||
Within the evaluation bla bla
|
||||
The evaluation following the transition then compares the predicted relative pressure with the observed one
|
||||
using a normal distribution with the previously estimated $\sigma_\text{baro}$:
|
||||
|
||||
\begin{equation}
|
||||
xx
|
||||
p(\mObsVec_t \mid \mStateVec_t)_\text{baro} = \mathcal{N}(\mObs_t^{\mObsPressure} \mid \mState_t^{\mStatePressure}, \sigma_\text{baro}).
|
||||
\label{eq:baroEval}
|
||||
\end{equation}
|
||||
|
||||
we use the system's setup time to not only determine the relative base but also for estimating the barometers
|
||||
uncertainty \sigma_\text{baro} used within the evaluation.
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
\subsection{Wi-Fi \& iBeacons}
|
||||
For additional absolute location hints, we use the Smartphones Wi-Fi and iBeacon sensor to measure the signal-strengths
|
||||
@@ -40,7 +55,7 @@
|
||||
and calculate the resulting probability as described in \cite{ipin2015}:
|
||||
|
||||
\begin{equation}
|
||||
\mProb(\mObsVec \mid \mStateVec)_\text{wifi} =
|
||||
\mProb(\mObsVec_t \mid \mStateVec_t)_\text{wifi} =
|
||||
\prod\limits_{i=1}^{n} \mathcal{N}(\mRssi_\text{wifi}^{i} \mid P_{r}(\mMdlDist_{i}, \Delta{f_{i}}), \sigma_{\text{wifi}}^2).
|
||||
\label{eq:wifiTotal}
|
||||
\end{equation}
|
||||
@@ -56,6 +71,9 @@
|
||||
Again, $\mPLE$ is determined emprically. \todo{faellt hier meist kleiner aus, weil ja kuerzere reichweite etc}
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
\subsection{Step- \& Turn-Detection}
|
||||
|
||||
To prevent degradation within the particle-filter \cite{??} due to downvoting of particles with increased
|
||||
|
||||
24
tex/gfx/baro/baro_setup_issue.aux
Normal file
24
tex/gfx/baro/baro_setup_issue.aux
Normal file
@@ -0,0 +1,24 @@
|
||||
\relax
|
||||
\@setckpt{gfx/baro/baro_setup_issue}{
|
||||
\setcounter{page}{3}
|
||||
\setcounter{equation}{3}
|
||||
\setcounter{enumi}{0}
|
||||
\setcounter{enumii}{0}
|
||||
\setcounter{enumiii}{0}
|
||||
\setcounter{enumiv}{0}
|
||||
\setcounter{footnote}{0}
|
||||
\setcounter{mpfootnote}{0}
|
||||
\setcounter{section}{4}
|
||||
\setcounter{subsection}{1}
|
||||
\setcounter{subsubsection}{0}
|
||||
\setcounter{paragraph}{0}
|
||||
\setcounter{IEEEsubequation}{0}
|
||||
\setcounter{figure}{0}
|
||||
\setcounter{table}{0}
|
||||
\setcounter{IEEEbiography}{0}
|
||||
\setcounter{parentequation}{0}
|
||||
\setcounter{ALC@unique}{0}
|
||||
\setcounter{ALC@line}{0}
|
||||
\setcounter{ALC@rem}{0}
|
||||
\setcounter{ALC@depth}{0}
|
||||
}
|
||||
1880
tex/gfx/baro/baro_setup_issue.csv
Executable file
1880
tex/gfx/baro/baro_setup_issue.csv
Executable file
File diff suppressed because it is too large
Load Diff
2257
tex/gfx/baro/baro_setup_issue.eps
Normal file
2257
tex/gfx/baro/baro_setup_issue.eps
Normal file
File diff suppressed because it is too large
Load Diff
23
tex/gfx/baro/baro_setup_issue.gp
Normal file
23
tex/gfx/baro/baro_setup_issue.gp
Normal file
@@ -0,0 +1,23 @@
|
||||
set terminal epslatex size 3.5,1.4
|
||||
set output "baro_setup_issue.eps"
|
||||
|
||||
unset arrow
|
||||
|
||||
set yrange[980.5:981.5]
|
||||
set xrange[0:50]
|
||||
set ytics 980.5, 0.2, 981.5
|
||||
|
||||
set lmargin 5.0
|
||||
set rmargin 1.4
|
||||
set tmargin 0.5
|
||||
|
||||
set object 1 rectangle from 0,980.5 to 4.000,981.3 fs solid fc rgb "#EEEEEE" behind
|
||||
set object 2 rectangle from 4.000,980.5 to 10.000,981.1 fs solid fc rgb "#DDDDDD" behind
|
||||
set object 3 rectangle from 10.000,980.5 to 36.000,980.9 fs solid fc rgb "#EEEEEE" behind
|
||||
set object 4 rectangle from 36.000,980.5 to 48.000,981.2 fs solid fc rgb "#DDDDDD" behind
|
||||
|
||||
set label 1 "error" at 0.500,981.38
|
||||
set label 2 "estimation" at 4.500, 981.18
|
||||
set label 3 "walk" at 10.500, 980.98
|
||||
set label 4 "stair" at 36.500, 981.28
|
||||
plot "baro_setup_issue.csv" using ($2/1000):4 with lines notitle lc rgb "black"
|
||||
108
tex/gfx/baro/baro_setup_issue.tex
Normal file
108
tex/gfx/baro/baro_setup_issue.tex
Normal file
@@ -0,0 +1,108 @@
|
||||
% GNUPLOT: LaTeX picture with Postscript
|
||||
\begingroup
|
||||
\makeatletter
|
||||
\providecommand\color[2][]{%
|
||||
\GenericError{(gnuplot) \space\space\space\@spaces}{%
|
||||
Package color not loaded in conjunction with
|
||||
terminal option `colourtext'%
|
||||
}{See the gnuplot documentation for explanation.%
|
||||
}{Either use 'blacktext' in gnuplot or load the package
|
||||
color.sty in LaTeX.}%
|
||||
\renewcommand\color[2][]{}%
|
||||
}%
|
||||
\providecommand\includegraphics[2][]{%
|
||||
\GenericError{(gnuplot) \space\space\space\@spaces}{%
|
||||
Package graphicx or graphics not loaded%
|
||||
}{See the gnuplot documentation for explanation.%
|
||||
}{The gnuplot epslatex terminal needs graphicx.sty or graphics.sty.}%
|
||||
\renewcommand\includegraphics[2][]{}%
|
||||
}%
|
||||
\providecommand\rotatebox[2]{#2}%
|
||||
\@ifundefined{ifGPcolor}{%
|
||||
\newif\ifGPcolor
|
||||
\GPcolorfalse
|
||||
}{}%
|
||||
\@ifundefined{ifGPblacktext}{%
|
||||
\newif\ifGPblacktext
|
||||
\GPblacktexttrue
|
||||
}{}%
|
||||
% define a \g@addto@macro without @ in the name:
|
||||
\let\gplgaddtomacro\g@addto@macro
|
||||
% define empty templates for all commands taking text:
|
||||
\gdef\gplbacktext{}%
|
||||
\gdef\gplfronttext{}%
|
||||
\makeatother
|
||||
\ifGPblacktext
|
||||
% no textcolor at all
|
||||
\def\colorrgb#1{}%
|
||||
\def\colorgray#1{}%
|
||||
\else
|
||||
% gray or color?
|
||||
\ifGPcolor
|
||||
\def\colorrgb#1{\color[rgb]{#1}}%
|
||||
\def\colorgray#1{\color[gray]{#1}}%
|
||||
\expandafter\def\csname LTw\endcsname{\color{white}}%
|
||||
\expandafter\def\csname LTb\endcsname{\color{black}}%
|
||||
\expandafter\def\csname LTa\endcsname{\color{black}}%
|
||||
\expandafter\def\csname LT0\endcsname{\color[rgb]{1,0,0}}%
|
||||
\expandafter\def\csname LT1\endcsname{\color[rgb]{0,1,0}}%
|
||||
\expandafter\def\csname LT2\endcsname{\color[rgb]{0,0,1}}%
|
||||
\expandafter\def\csname LT3\endcsname{\color[rgb]{1,0,1}}%
|
||||
\expandafter\def\csname LT4\endcsname{\color[rgb]{0,1,1}}%
|
||||
\expandafter\def\csname LT5\endcsname{\color[rgb]{1,1,0}}%
|
||||
\expandafter\def\csname LT6\endcsname{\color[rgb]{0,0,0}}%
|
||||
\expandafter\def\csname LT7\endcsname{\color[rgb]{1,0.3,0}}%
|
||||
\expandafter\def\csname LT8\endcsname{\color[rgb]{0.5,0.5,0.5}}%
|
||||
\else
|
||||
% gray
|
||||
\def\colorrgb#1{\color{black}}%
|
||||
\def\colorgray#1{\color[gray]{#1}}%
|
||||
\expandafter\def\csname LTw\endcsname{\color{white}}%
|
||||
\expandafter\def\csname LTb\endcsname{\color{black}}%
|
||||
\expandafter\def\csname LTa\endcsname{\color{black}}%
|
||||
\expandafter\def\csname LT0\endcsname{\color{black}}%
|
||||
\expandafter\def\csname LT1\endcsname{\color{black}}%
|
||||
\expandafter\def\csname LT2\endcsname{\color{black}}%
|
||||
\expandafter\def\csname LT3\endcsname{\color{black}}%
|
||||
\expandafter\def\csname LT4\endcsname{\color{black}}%
|
||||
\expandafter\def\csname LT5\endcsname{\color{black}}%
|
||||
\expandafter\def\csname LT6\endcsname{\color{black}}%
|
||||
\expandafter\def\csname LT7\endcsname{\color{black}}%
|
||||
\expandafter\def\csname LT8\endcsname{\color{black}}%
|
||||
\fi
|
||||
\fi
|
||||
\setlength{\unitlength}{0.0500bp}%
|
||||
\ifx\gptboxheight\undefined%
|
||||
\newlength{\gptboxheight}%
|
||||
\newlength{\gptboxwidth}%
|
||||
\newsavebox{\gptboxtext}%
|
||||
\fi%
|
||||
\setlength{\fboxrule}{0.5pt}%
|
||||
\setlength{\fboxsep}{1pt}%
|
||||
\begin{picture}(5040.00,2014.00)%
|
||||
\gplgaddtomacro\gplbacktext{%
|
||||
\csname LTb\endcsname%
|
||||
\put(528,440){\makebox(0,0)[r]{\strut{}$980.5$}}%
|
||||
\put(528,733){\makebox(0,0)[r]{\strut{}$980.7$}}%
|
||||
\put(528,1025){\makebox(0,0)[r]{\strut{}$980.9$}}%
|
||||
\put(528,1318){\makebox(0,0)[r]{\strut{}$981.1$}}%
|
||||
\put(528,1610){\makebox(0,0)[r]{\strut{}$981.3$}}%
|
||||
\put(528,1903){\makebox(0,0)[r]{\strut{}$981.5$}}%
|
||||
\put(660,220){\makebox(0,0){\strut{}$0$}}%
|
||||
\put(1499,220){\makebox(0,0){\strut{}$10$}}%
|
||||
\put(2338,220){\makebox(0,0){\strut{}$20$}}%
|
||||
\put(3176,220){\makebox(0,0){\strut{}$30$}}%
|
||||
\put(4015,220){\makebox(0,0){\strut{}$40$}}%
|
||||
\put(4854,220){\makebox(0,0){\strut{}$50$}}%
|
||||
\put(702,1727){\makebox(0,0)[l]{\strut{}error}}%
|
||||
\put(1037,1435){\makebox(0,0)[l]{\strut{}estimation}}%
|
||||
\put(1541,1142){\makebox(0,0)[l]{\strut{}walk}}%
|
||||
\put(3722,1581){\makebox(0,0)[l]{\strut{}stair}}%
|
||||
}%
|
||||
\gplgaddtomacro\gplfronttext{%
|
||||
}%
|
||||
\gplbacktext
|
||||
\put(0,0){\includegraphics{baro_setup_issue}}%
|
||||
\gplfronttext
|
||||
\end{picture}%
|
||||
\endgroup
|
||||
Reference in New Issue
Block a user