This repository has been archived on 2021-05-17. You can view files and clone it, but cannot push or open issues or pull requests.
scientificComputing/programming/lectures/data_structures.tex
2015-10-15 18:10:25 +02:00

324 lines
7.8 KiB
TeX

\documentclass{beamer}
\usepackage{xcolor}
\usepackage{listings}
\usepackage{pgf}
%\usepackage{pgf,pgfarrows,pgfnodes,pgfautomata,pgfheaps,pgfshade}
%\usepackage{multimedia}
\usepackage[english]{babel}
\usepackage{movie15}
\usepackage[latin1]{inputenc}
\usepackage{times}
\usepackage{amsmath}
\usepackage{bm}
\usepackage[T1]{fontenc}
\usepackage[scaled=.90]{helvet}
\usepackage{scalefnt}
\usepackage{tikz}
\usepackage{ textcomp }
\usepackage{color, soul}
\usepackage{hyperref}
\definecolor{lightblue}{rgb}{.7,.7,1.}
\definecolor{mygreen}{rgb}{0.4,1.,0.4}
\definecolor{stringcolor}{rgb}{0.1,0.6,0.1}
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\mode<presentation>
{
\usetheme{Singapore}
\setbeamercovered{opaque}
\usecolortheme{tuebingen}
\setbeamertemplate{navigation symbols}{}
\usefonttheme{default}
\useoutertheme{infolines}
% \useoutertheme{miniframes}
}
\AtBeginSection[]
{
\begin{frame}<beamer>
\begin{center}
\Huge \insertsectionhead
\end{center}
% \frametitle{\insertsectionhead}
% \tableofcontents[currentsection,hideothersubsections]
\end{frame}
}
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%5
\setbeamertemplate{blocks}[rounded][shadow=true]
\title[]{Scientific Computing -- Grundlagen der Programmierung }
\author[]{Jan Grewe\\Abteilung f\"ur Neuroethologie\\
Universit\"at T\"ubingen}
\institute[Wissenschaftliche Datenverarbeitung]{}
\date{12.10.2015 - 06.11.2015}
%\logo{\pgfuseimage{../../resources/UT_BM_Rot_RGB.pdf}}
\subject{Einf\"uhrung in die wissenschaftliche Datenverarbeitung}
\vspace{1em}
\titlegraphic{
\includegraphics[width=0.5\linewidth]{../../resources/UT_WBMW_Rot_RGB}
}
%%%%%%%%%% configuration for code
\lstset{
basicstyle=\ttfamily,
numbers=left,
showstringspaces=false,
language=Matlab,
commentstyle=\itshape\color{darkgray},
keywordstyle=\color{blue},
stringstyle=\color{stringcolor},
backgroundcolor=\color{blue!10},
breaklines=true,
breakautoindent=true,
columns=flexible,
frame=single,
captionpos=b,
xleftmargin=1em,
xrightmargin=1em,
aboveskip=10pt
}
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\newcommand{\mycite}[1]{
\begin{flushright}
\tiny \color{black!80} #1
\end{flushright}
}
\input{../../latex/environments.tex}
\makeatother
\begin{document}
\begin{frame}[plain]
\frametitle{}
\vspace{-1cm}
\titlepage % erzeugt Titelseite
\end{frame}
\begin{frame}[plain]
\huge{1. Fortgeschrittene Datenstrukturen}
\end{frame}
\begin{frame}
\frametitle{Fortgeschrittene Datenstrukturen}
\framesubtitle{``Strukturen'' und ``Cell Arrays''}
\large
Bisher kennen wir folgende Datenstrukturen:
\begin{enumerate}
\item Skalare.
\item Vektoren.
\item Matrizen.
\end{enumerate}\pause
F\"ur die meisten F\"alle reicht das aus. Manchmal m\"ochte man aber
Dinge gemeinsam ablegen, die nicht den gleichen Datentyp haben.
\pause\\
Beispiel: Ich habe eine Reihe Versuchspersonen bei denen ich
verschiede Parameter (Alter, Geschlecht) zusammen mit den
Testergebnissen ablegen m\"ochte.
\end{frame}
\begin{frame}
\frametitle{Fortgeschrittene Datenstrukturen}
\framesubtitle{``Strukturen'' und ``Cell Arrays''}
\only<1> {
F\"ur diese Zwecke kennt MATLAB vier weitere Datenstrukturen:
\begin{enumerate}
\item Strukturen.
\item Cell Arrays.
\item Tabellen (neu seit 2013).
\item Objekte.
\end{enumerate}
}
\only <2> {
F\"ur diese Zwecke kennt MATLAB \st{vier} \textbf{drei} weitere Datenstrukturen:
\begin{enumerate}
\item Strukturen.
\item Cell Arrays.
\item Tabellen (neu seit 2013).
\item \st{Objekte.}
\end{enumerate}
}
\end{frame}
\begin{frame}[fragile]
\frametitle{Fortgeschrittene Datenstrukturen}
\framesubtitle{``Strukturen'' und ``Cell Arrays''}
\huge{Strukturen}
\end{frame}
\begin{frame}[fragile]
\frametitle{Fortgeschrittene Datenstrukturen}
\framesubtitle{``Strukturen'' und ``Cell Arrays''}
\begin{itemize}
\item Strukturen werden benutzt um beliebige zusammengeh\"orige
Daten in sog. Kontainern zu speichern.
\item Diese Daten k\"onnen \"uber den Namen des Kontainers oder
``Feldes'' angesprochen werden.
\item Man kann Listen von diesen Strukturen haben.
\end{itemize}
\end{frame}
\begin{frame}[fragile]
\frametitle{Fortgeschrittene Datenstrukturen}
\framesubtitle{Strukturen}
Beispiel:
\footnotesize
\begin{lstlisting}
subjects(1).name = 'John Dow';
subjects(1).age = 35;
subjects(1).sex = 'm';
subjects(1).results = [1 2 3 4 5];
subjects(2).name = 'Jane Smith';
subjects(2).age = 32;
subjects(2).sex = 'f';
subjects(2).results = [1 2 3 4 5];
fieldnames(subjects)
ans =
'name'
'age'
'sex'
'results'
\end{lstlisting}
\end{frame}
\begin{frame}[fragile]
\frametitle{Fortgeschrittene Datenstrukturen}
\framesubtitle{Strukturen}
Beispiel:
\footnotesize
\begin{lstlisting}
subjects(1).name
ans =
'John Doe'
subjects(1).test2 = [];
fieldname(subjects(2))
ans =
'name'
'age'
'sex'
'results'
'test2'
\end{lstlisting}
\end{frame}
\begin{frame}[fragile]
\frametitle{Fortgeschrittene Datenstrukturen}
\framesubtitle{Strukturen}
\textbf{Vorteile:}
\begin{enumerate}
\item Strukturen koennen beliebige Werte aufnehmen.
\item Man kann Listen von Strukturen erstellen und darauf
indizieren.
\item Sind sehr leicht lesbar.
\item Addressieren von Feldern ist sehr intuitiv.
\end{enumerate}
\pause
\vspace{1cm}
\textbf{Nachteile:}
\begin{enumerate}
\item Alle Eintr\"age in einer Strukturliste m\"ussen gleichgefromt
sein.
\item Kein logisches Indizieren.
\item Elemente der Strukturen m\"ussen \"uber den Feldnamen
angesprochen werden.
\end{enumerate}
\end{frame}
\begin{frame}[fragile]
\frametitle{Fortgeschrittene Datenstrukturen}
\framesubtitle{``Strukturen'' und ``Cell Arrays''}
\huge{Cell Arrays}
\end{frame}
\begin{frame}
\frametitle{Fortgeschrittene Datenstrukturen}
\framesubtitle{Cell Arrays}
\begin{enumerate}
\item Matrizen k\"onnen nur rechtwinklig sein.
\item Manchmal hat man aber unterschiedlich viele Datenpunkte, die
dennoch logisch zusammengeh\"oren.
\item Z.B. Wenn man Zeitpunkte von Neuronalen- oder Verhaltensereignissen hat.
\end{enumerate}
\end{frame}
\begin{frame}[fragile]
\frametitle{Fortgeschrittene Datenstrukturen}
\framesubtitle{Cell Arrays}
\scriptsize
\begin{lstlisting}
>> % create a cell array
>> cell_array = {};
>>
>> % assignment of arbitrary content
>> cell_array{1} = ones(100,1);
>> cell_array{2} = ones(10000,100);
>> cell_array{3} = 'das ist ein Test';
>> cell_array{4} = {};
>>
>> % accessing of content
>> size(cell_array{1})
ans =
100 1
>>
\end{lstlisting}
\end{frame}
\begin{frame}
\frametitle{Fortgeschrittene Datenstrukturen}
\framesubtitle{Cell Arrays}
\textbf{Vorteile:}
\begin{enumerate}
\item Kann alle m\"oglichen Daten ablegen.
\item Benutzung m\"oglich ohne Kenntnis von Feldnamen.
\end{enumerate}\pause
\vspace{1cm}
\textbf{Nachteile:}
\begin{enumerate}
\item Manchmal un\"ubersichtlich.
\item Adressieren mit ${}$ ist eher ungew\"ohnlich.
\end{enumerate}
\end{frame}
\begin{frame}[fragile]
\frametitle{Fortgeschrittene Datenstrukturen}
\framesubtitle{``Strukturen'' und ``Cell Arrays''}
\huge{Tabellen}
\end{frame}
\begin{frame}
\frametitle{Fortgeschrittene Datenstrukturen}
\framesubtitle{Tabellen}
\begin{enumerate}
\item Datenstruktur \"ahnlich zu Excel Tabellen.
\item Jede Spalte ist eine Kategorie.
\item Verschiedene Spalten k\"onnen unterschiedliche Datentypen
haben.
\item Unterst\"utzung von Filteroperationen auf Spalten und Zeilen.
\item Kann direkt \textit{*.xlsx} Dateien importieren.
\end{enumerate}
\end{frame}
\begin{frame}[fragile]
\frametitle{Fortgeschrittene Datenstrukturen}
\framesubtitle{Tabellen}
\scriptsize
\begin{lstlisting}
\end{lstlisting}
\end{frame}
\end{document}