9a18aef4271a4ec41557d4a095274f560ed934a5
[diplomarbeit.git] / diplomarbeit.tex
1 \documentclass[a4paper,11pt]{article}
2 \usepackage[utf8]{inputenc}
3 \usepackage{ngerman}
4 \usepackage{fancyhdr}
5 \usepackage{geometry}
6 \usepackage{amsmath, bbm}
7 \usepackage{amsfonts}
8 \usepackage{amssymb}
9 \usepackage{listings}
10 \usepackage{graphicx}
11 \usepackage{url}
12 %\usepackage{longtable}
13 \usepackage{subfigure}
14 \usepackage{icomma}
15
16 \usepackage{tikz}
17 \usetikzlibrary{arrows,shapes}
18
19 % Fuer mathtoolsset
20 \usepackage{mathtools}
21
22 \geometry{paper=a4paper,margin=30mm}
23
24 \pagestyle{fancy}
25 %\fancyhf{}
26 %\fancyhead[LO,LE]{"Ubung zu Computational Intelligence}
27 %\fancyhead[CO,CE]{2006-05-15}
28 %\fancyhead[RO,RE]{Florian Forster (2099894)}
29
30 \title{Evolutionäre Optimierung von Sortiernetzwerken}
31 \author{Florian Forster}
32 \date{\today}
33
34 \newcommand{\false}{\textsc{False}}
35 \newcommand{\true}{\textsc{True}}
36 \newcommand{\todo}[1]{{\bf TODO:} #1}
37 \newcommand{\qed}{\hfill $\Box$ \par \bigskip}
38
39 \newtheorem{definition}{Definition}
40 \newtheorem{satz}{Satz}
41
42 % Zeige Nummern nur bei referenzierten Gleichungen an.
43 \mathtoolsset{showonlyrefs=true}
44
45 \begin{document}
46
47 \tikzstyle{vertex}   = [circle,draw,thick,fill=black,minimum size=5,inner sep=0pt]
48 \tikzstyle{comp}     = [draw,thick,-]
49 \tikzstyle{compup}   = [draw,thick,->]
50 \tikzstyle{compdown} = [draw,thick,<-]
51 \tikzstyle{edge}     = [draw,thick,-]
52 \tikzstyle{diredge}  = [draw,thick,->]
53 \tikzstyle{prob}     = [font=\tiny]
54
55 \tikzstyle{edge minimum} = [edge,color=blue!20]
56 \tikzstyle{edge maximum} = [edge,color=red!20]
57 \tikzstyle{vertex active minimum} = [vertex,color=blue!50, fill=blue!50]
58 \tikzstyle{vertex active maximum} = [vertex,color=red!50, fill=red!50]
59 \tikzstyle{vertex active minimum maximum} = [vertex,color=violet!50, fill=violet!50]
60 \tikzstyle{vertex inactive minimum} = [vertex,color=blue!20, fill=blue!20]
61 \tikzstyle{vertex inactive maximum} = [vertex,color=red!20, fill=red!20]
62 \tikzstyle{vertex inactive minimum maximum} = [vertex,color=black!20, fill=black!20]
63 \tikzstyle{comp active minimum} = [comp]
64 \tikzstyle{comp active maximum} = [comp]
65 \tikzstyle{comp active minimum maximum} = [comp,color=black!20]
66 \tikzstyle{comp inactive minimum} = [comp,color=blue!20]
67 \tikzstyle{comp inactive maximum} = [comp,color=red!20]
68 \tikzstyle{comp inactive minimum maximum} = [comp,color=black!20]
69
70 \tikzstyle{red box}   = [draw,-,color=red, top color=red!2,bottom color=red!10]
71 \tikzstyle{blue box}  = [draw,-,color=blue,top color=blue!2,bottom color=blue!10]
72 \tikzstyle{green box} = [draw,-,color=teal,top color=teal!2,bottom color=teal!10]
73 \tikzstyle{gray box}  = [draw,-,color=black, top color=black!2,bottom color=black!10]
74
75 \maketitle
76 \begin{abstract}
77 Sortiernetzwerke werden eingeführt und einige bekannte Konstruktionen werden
78 vorgestellt (Off-Even-Transposition, Bitonic-Merge, Odd-Even-Merge, Pairwise).
79 Transformationsmöglichkeiten für Sortiernetzwerke werden besprochen.
80 Evolutionäre Algorithmen werden beschrieben und ein evolutionärer
81 Algorithmus für die Optimierung von Sortiernetzwerken wird angegeben.
82 Die mindestens von diesem Algorithmus erreichte Güte wird angegeben und die
83 Transformation zu einer Markov-Kette wird gezeigt. {\em Natürlich: So fern ich
84 das hinbekomme bzw. Recht behalte.}
85 \end{abstract}
86 \newpage
87
88 \tableofcontents
89
90 \newpage
91 \section{Motivation und Einleitung}
92
93 \subsection{Motivation}\label{sect:motivation}
94
95 \begin{itemize}
96 \item Sortiernetzwerke sind toll, weil $\ldots$
97 \item Sortiernetzwerke sind einfach erklärt, aber trotzdem kompliziert.
98 \item Bisher noch kein evolutionärer Algorithmus zur automatischen
99   Optimierung von Sortiernetzwerken bekannt. \textit{(Glaube ich zumindest.)}
100 \end{itemize}
101
102 \subsection{Einleitung}\label{sect:einleitung}
103
104 \subsubsection{Sortiernetzwerke}\label{sect:einleitung_sortiernetzwerke}
105
106 \emph{Komparatoren} sind die Bausteine, die \emph{Komparatornetzwerken}
107 zugrunde liegen. Sie haben zwei Eingänge über die sie zwei Zahlen erhalten
108 können und zwei Ausgänge, auf denen die Zahlen wieder ausgegeben werden. Dabei
109 sind die Ausgänge im Gegensatz zu den Eingängen unterscheidbar, da die größere
110 der beiden Zahlen wird immer auf dem einen, die kleinere der beiden Zahlen
111 immer auf dem anderen Ausgang ausgegeben ausgegeben wird.
112
113 Kombiniert man mehrere \emph{Komparatoren} miteinander, das heißt, dass die
114 Ausgänge eines Komparators mit Eingängen weiterer Komparatoren verbunden sind,
115 erhält man ein {\em Komparatornetzwerk}.
116
117 \begin{figure}
118 \begin{center}
119 \input{images/einfaches_komparatornetzwerk.tex}
120 \end{center}
121 \caption{Einfaches Komparatornetzwerk mit vier Ein- bzw. Ausgängen, bestehend
122 aus 5~Komparatoren.}
123 \label{fig:einfaches_komparatornetzwerk}
124 \end{figure}
125
126 Abbildung~\ref{fig:einfaches_komparatornetzwerk} zeigt ein einfaches
127 \emph{Komparatornetzwerk} aus fünf Komparatoren. Insgesamt gibt es vier
128 verschiedene Eingänge und vier Ausgänge. Die Ein- und Ausgänge werden durch
129 eine horizontale Linie dargestellt und als \emph{Leitung} bezeichnet. Die
130 \emph{Komparatoren} sind durch vertikale Pfeile dargestellt und verbinden je
131 zwei verschiedene \emph{Leitungen} miteinander. Die Verbindungsstellen von
132 \emph{Leitungen} und \emph{Komparatoren} sind zur besseren Übersichlichkeit
133 durch schwarze Punkte symbolisiert.
134
135 Auf der linken Seite befinden sich die Eingänge. Hier wird eine Zahlenfolge in
136 das Netzwerk hineingegeben. Jeder Komparator vergleicht die Zahlen „auf“ den
137 beiden Leitungen, die er verbindet. Nach einem Komparator befindet sich die
138 kleinere Zahl immer auf der Leitung, auf die der Pfeil zeigt, die größere Zahl
139 befindet sich auf der Leitung, auf der der Pfeil seinen Ursprung hat.
140
141 Komparatoren, die unterschiedliche Leitungen miteinander vergleichen, können
142 gleichzeitig angewandt werden. Das Beispiel in
143 Abbildung~\ref{fig:einfaches_komparatornetzwerk} verwendet diesen Umstand und
144 vergleicht die zwei oberen und die zwei unteren Leitungen gleichzeitig. Eine
145 Gruppe von Komparatoren, die gleichzeitig angewendet werden können, nennt man
146 eine \emph{Schicht} des Komparatornetwerks. Die \emph{Verzögerung} eines
147 Komparatornetzwerks ist gleichbedeutend mit der Anzahl der Schichten, in die
148 sich die Komparatoren mindestens gruppieren lassen, da sie die Anzahl der
149 benötigten parallelen Schritte darstellt.
150
151 \emph{Komparatornetzwerke}, die für \emph{jede} Eingabefolge eine Ausgabe
152 erzeugen, die der Sortierung der Eingabe entspricht, heißen
153 \emph{Sortiernetzwerke}. Das in
154 Abbildung~\ref{fig:einfaches_komparatornetzwerk} gezeigte Komparatornetzwerk
155 ist \emph{kein} Sotiernetzwerk: Die Eingabefolge ${(1, 2, 3, 4)}$ führt zur
156 Ausgabe ${(2, 1, 3, 4)}$ -- die bestehenden Sortierung wird also sogar
157 zerstört.
158
159 \begin{figure}
160   \begin{center}
161     \input{images/09-e2-c24-allbut1.tex}
162   \end{center}
163   \caption{Ein \emph{Komparatornetzwerk} mit neun Eingängen und
164   24~Komparatoren, die in 8~Schichten angeordnet sind. Das Netzwerk sortiert
165   alle Eingaben, bei denen das Minimum nicht auf dem mittleren Eingang liegt.}
166   \label{fig:09-e2-c24-allbut1}
167 \end{figure}
168 Zu beweisen, dass ein gegebenes Komparatornetzwerk die Sortiereigenschaft {\em
169 nicht} hat, ist mit einem gegebenen Gegenbeispiel einfach möglich. Das
170 Komparatornetzwerk wird auf das Gegenbeispiel angewendet und anschließend wird
171 überprüft, ob die Ausgabe sortiert ist. Ist sie es nicht heißt das, dass es
172 mindestens eine Eingabefolge gibt, die nicht sortiert wird. Entsprechend der
173 Definition handelt es sich bei dem \emph{Komparatornetzwerk} folglich
174 \emph{nicht} um ein \emph{Sortiernetzwerk}. Ein solches Gegenbeispiel für ein
175 gegebenes Komparatornetzwerk zu finden ist nach heutigem Kenntnisstand jedoch
176 nicht \emph{effizient} möglich.
177
178 Beispielsweise sortiert das Komparatornetzwerk in
179 Abbildung~\ref{fig:09-e2-c24-allbut1} viele der 362.880 möglichen
180 Eingabepermutationen. Mit dem Gegenbeispiel $(3, 5, 2, 1, 0, 7, 4, 8, 6)$
181 lässt sich jedoch leicht beweisen, dass das Komparatornetzwerk die
182 Sortiereigenschaft \emph{nicht} besitzt, da es in diesem Fall die Folge
183 $(1, 0, 2, 3, 4, 5, 6, 7, 8)$ ausgibt.
184
185 Insgesamt gibt es $n!$~Permutationen von $n$~Elementen. Wenn ein
186 Komparatornetzwerk die Sortiereigenschaft besitzt, bildet es alle diese
187 Permutationen auf die sortierte Reihenfolge ab. Allerdings wächst $n!$
188 über-exponentiell schnell, so dass ein Ausprobieren aller möglichen
189 Permutationen schon bei 16~Leitungen praktisch nicht mehr zu bewerkstelligen
190 ist.\footnote{1.307.674.368.000 Permutationen}
191
192 Glücklicherweise reicht es aus, alle möglichen 0-1-Folgen zu überprüfen, wie
193 \textit{Donald~E. Knuth} in \cite{KNUTH} zeigt. Die Beweisidee ist folgende:
194 Angenommen ein Komparatornetzwerk sortiert alle 0-1-Folgen und es gibt eine
195 Permutation $E = (e_0, \dots, e_{n-1})$ beliebiger Zahlen, die nicht sortiert
196 wird. Die Ausgabefolge sei $A = (a_0, \dots, a_{n-1})$. Sei $i$ eine Position
197 in der Ausgabe, die die Sortierbedingung verletzt:
198 \begin{displaymath}
199   a_0 \leqq a_1 \leqq \dots \leqq a_{i-1} > a_i \dots
200 \end{displaymath}
201 Die Eingabe kann mittels
202 \begin{displaymath}
203   \hat{e}_j = \left\{
204     \begin{array}{cl}
205       0 & e_j \leqq a_i \\
206       1 & e_j > a_i
207     \end{array} \right.
208 \end{displaymath}
209 auf eine 0-1-Folge abgebildet werden, die entsprechen der Annahme von
210 Komparatornetzwerk sortiert wird. Allerdings verändert diese Abbildung das
211 Verhalten jedes einzelnen Komparators nicht, so dass die Annahme auf einen
212 Widerspruch geführt wird.
213
214 Im Gegensatz zum Überprüfen aller möglichen Permutationen, was der
215 Komplexitätsklasse
216 $\mathcal{O}\left(\sqrt{n}\left(\frac{n}{e}\right)^n\right)$ zuzuordnen ist,
217 ist das Überprüfen aller 0-1-Folgen „nur“ mit dem Aufwand $\mathcal{O}(2^n)$
218 verbunden. Entsprechend ist dieses Verfahren nicht \emph{effizient} -- ein
219 schnelleres Verfahren ist bisher allerdings nicht bekannt. Um zu überprüfen,
220 ob ein Komparatornetzwerk mit 16~Leitungen die Sortiereigenschaft besitzt,
221 sind mit dieser Methode nur 65.536 Tests notwendig -- eine Zahl, die für
222 aktuelle Prozessoren keine Herausforderung darstellt. Für die Überprüfung
223 eines Komparatornetzwerks mit 32~Leitungen sind jedoch bereits etwa
224 4,3~Millarden Tests notwendig, die einen Rechner durchaus mehrere Minuten
225 beschäftigen.
226
227 \subsubsection{Evolutionäre Algorithmen}
228
229 Viele {\em kombinatorische Optimierungsprobleme} sind schwer zu lösen -- die
230 entsprechenden Entscheidungsprobleme liegen oft in der Komplexitätsklasse
231 $NP$, sind also mit bekannten Verfahren nicht effizient exakt lösbar. Sollte
232 sich herausstellen, dass diese Probleme nicht in der Komplexitätsklasse $P$
233 liegen, wäre eine Konsequenz, dass es effiziente exakte Algorithmen für diese
234 Probleme nicht geben kann. Falls sich hingegen herausstellt, dass diese
235 Probleme in der Komplexitätsklasse~$P$ liegen, wird es mit großer
236 Wahrscheinlichkeit noch einige Zeit dauern bis auch Algorithmen mit
237 praktikablen Zeitkonstanten gefunden werden.
238
239 Aus diesem Grund besteht die Notwendigkeit einen Kompromiss einzugehen: Statt
240 die bzw. eine der {\em optimalen} Lösungen als einzige Ausgabe des Algorithmus
241 zuzulassen, wird eine "`möglichst gute"' Lösung ausgegeben. Viele dieser
242 Optimierungsalgorithmen orientieren sich an Vorgängen in der Natur,
243 beispielsweise immitieren die "`Ameisenalgorithmen"' das Verhalten von Ameisen
244 auf der Futtersuche um kurze Rundreisen auf Graphen zu berechnen.
245
246 Bei {\em Evolutionären Algorithmen} stand die Evolution pate. Die Grundidee
247 ist es, bestehende Lösungen zu neuen, unter Umständen besseren Lösungen zu
248 kombinieren. Dabei bedient man sich der in der Evolutionstheorie etablierten
249 Nomenklatur, beispielsweise werden konkrete Lösungen für ein Problem häufig
250 als {\em Individuum} bezeichnet.
251
252 Die Vorgehensweise lässt sich abstrakt wie folgt beschreiben. Aus einer
253 bestehenden Lösungsmenge, der {\em Population} werden zufällig Lösungen
254 ausgesucht {\em (Selektion)} und zu einer neuen Lösung kombiniert ({\em
255 Rekombination}). Unter Umständen wird die neue Lösung noch zufällig
256 verändert {\em (Mutation)}, bevor sie in die bestehende Lösungsmenge
257 integriert wird. Die Wahrscheinlichkeiten, beispielsweise bei der {\em
258 Selektion}, sind dabei nicht zwangsläufig gleichverteilt -- üblicherweise
259 werden bessere Lösungen bevorzugt. Zur Bewertung dient die sogenannte {\em
260 Gütefunktion}.
261
262 Nicht alle Probleme eignen sich für diese Strategie: Zum einen muss es möglich
263 sein, eine initiale Population zur Verfügung zu stellen, da diese als Basis
264 aller weiteren Operationen dient. Das ist häufig keine große Einschränkung, da
265 es oft einfach ist {\em irgendeine} Lösung anzugeben. Zum anderen muss eine
266 Methode für die Rekombination existieren. Das insbesondere dann problematisch
267 wenn {\em Nebenbedingungen} eingehalten werden müssen.
268
269 Beim Aussuchen von zufälligen Lösungen aus der Population, der
270 \emph{Selektion}, werden gute Lösungen bevorzugt. Wie sehr diese Lösungen
271 bevorzugt werden, hat einen starken Einfluss auf das Verhalten des
272 Algorithmus. Werden gute Lösungen stark bevorzugt, konvergiert der Algorithmus
273 schnell gegen ein (lokales) Optimum. Dieses \textit{Exploitation} (Englisch
274 für „Ausnutzung“) genannte Verhalten sorgt dafür, dass sich der Algorithmus
275 schnell auf eine Lösung festlegt und andere, möglicherweise bessere lokale
276 Optima nicht mehr findet. Werden gute Lösungen hingegen nur wenig bevorzugt,
277 erforscht der Algorithmus den Lösungsraum in viele Richtungen. Dieses
278 \textit{Exploration} (Englisch für „Erforschung“) genannte Verhalten sorgt
279 zwar dafür, dass der Algorithmus langsamer auf ein Optimum zusteuert, dafür
280 findet er aber in der Regel bessere Lösungen.
281
282 Die Parameter evolutionärer Algorithmen so einzustellen, dass sich ein guter
283 Mittelweg zwischen den beiden Extremen einstellt, ist eine Aufgabe, die sich
284 nur experimentell lösen lässt. Die genauen Parameter hängen nicht nur vom
285 eigentlichen Algorithmus, sondern auch vom konkreten Problem ab, so dass sich
286 beispielsweise bei der Optimierung von Sortiernetzwerken die Parameter
287 zwischen verschiedenen Leitungszahlen stark unterscheiden.
288
289 \begin{itemize}
290 \item Unter einem "`Evolutionären Algorithmus"' versteht man $\ldots$
291 \item Da die Sortiereigenschaft zu überprüfen NP-schwer ist, ist die
292 Mutation \textit{(vermutlich)} nicht (effizient) möglich.
293 \end{itemize}
294
295 \newpage
296 \section{Bekannte konstruktive Sortiernetzwerke}
297 \label{sect:konstruktive_netzwerke}
298
299 Übersicht über bekannte konstruktive Sortiernetzwerke.
300
301 \subsection{Das Odd-Even-Transpositionsort-Netzwerk}
302 \label{sect:odd_even_transpositionsort}
303
304 Das Sortiernetzwerk {\em Odd-Even-Transpositionsort} (OET) ist eines der
305 einfachsten Sortiernetzwerke. Es besteht aus $n$~{\em Schichten}, die jede
306 "`Leitung"' abwechselnd mit den benachbarten Leitungen verbindet.
307 Abbildung~\ref{fig:odd-even-transposition-08} zeigt das OET-Netzwerk für
308 ${n = 8}$ Leitungen.
309
310 \begin{figure}
311   \begin{center}
312     \input{images/oe-transposition-8.tex}
313   \end{center}
314   \caption{Das \emph{Odd-Even-Transpositionsort}-Netzwerk mit acht Eingängen.}
315   \label{fig:odd-even-transposition-08}
316 \end{figure}
317
318 Dass das Odd-Even-Transporitionsort-Netzwerk tatsächlich jede beliegibe
319 Eingabe sortiert ist nicht offensichtlich. Leicht zu sehen ist jedoch, dass
320 sowohl das Minimum als auch das Maximum durch das im Netzwerk enthaltene
321 Treppenmuster auf die unterste beziehungsweise oberste Leitung gelangt. Beim
322 Odd-Even-Transporitionsort-Netzwerk mit drei Eingängen,
323 $\operatorname{OET}(3)$, ist die Ausgabe folglich sortiert.
324
325 Die Sortiereigenschaft größerer OET-Netzwerke lässt sich rekursiv beweisen,
326 indem man $\operatorname{OET}(n)$ auf $\operatorname{OET}(n-1)$ durch
327 Herausschneiden einer Leitung reduziert. In
328 Abschnitt~\ref{sect:leitungen_entfernen} wird das Vorgehen im Detail
329 beschrieben, Abbildung~\ref{fig:oe-transposition-cut} zeigt das
330 Herausschneiden einer Leitung aus $\operatorname{OET}(8)$.
331
332 Das Odd-Even-Transporitionsort-Netzwerk ist weder in Bezug auf die Anzahl der
333 Komparatoren noch in Bezug auf die Anzahl der Schichten, in denen sich die
334 Komparatoren anordnen lassen, effizient. Es benötigt
335 ${\frac12 n (n-1)} = \mathcal{O}(n^2)$~Komparatoren, die in $n$~Schichten
336 angeordnet sind. Andere Sortiernetzwerke benötigen deutlich weniger
337 Komparatoren, beispielsweise $\mathcal{O}(n (\log n)^2)$, die in weniger
338 Schichten, zum Beispiel $\mathcal{O}(\log n)$, angeordnet sind.
339
340 Das Interessante am OET-Netzwerk ist seine einfache Konstruktion. Einige der
341 folgenden Algorithmen benötigen ein möglichst einfaches Sortiernetzwerk als
342 Starteingabe, auf dessen Basis sie versuchen optimierte Sortiernetzwerke zu
343 finden. Häufig dient $\operatorname{OET}(n)$ als Eingabe für diese
344 Algorithmen.
345
346 \subsection{Das bitone Mergesort-Netzwerk}
347
348 Das \emph{bitone Mergesort}-Netzwerk ($\operatorname{BS}(n)$) ist ein
349 Sortiernetzwerk, das 1968 von \emph{Kenneth~E. Batcher} in~\cite{B1968}
350 veröffentlicht wurde. Es ist deutlich effizienter als das
351 Odd-Even-Transposi\-tionsort-Netzwerk -- sowohl in Bezug auf die Anzahl der
352 Komparatoren als auch bezüglich der benötigten Zeit, also der Anzahl der
353 Schichten.
354
355 Das Sortiernetzwerk basiert auf einem Komparatornetzwerk, welches zwei
356 sortierte Listen zusammenfügen (englisch: \textit{to~merge}) kann. Dieser
357 \emph{„bitoner Mischer“} (englisch: \textit{bitonic merger}) genannte Baustein
358 verleiht dem Sortiernetzwerk seinen Namen.
359
360 Da das Sortiernetzwerk rekursiv definiert ist, betrachten wir hier nur die
361 Instanzen des Netzwerks, deren Leitungszahl $n = 2^t$ eine Zweierpotenz ist.
362 Es ist jedoch möglich das Sortiernetzwerk für beliebige~$n$ zu erzeugen.
363
364 \subsubsection{Der bitone Mischer}\label{sect:der_bitone_mischer}
365
366 Das \emph{bitone Mergesort-Netzwerk} basiert auf dem sogenannten \emph{bitonen
367 Mischer} $\operatorname{BM}(n)$, einem Kom\-parator-Netzwerk, das eine beliebige
368 \emph{bitone Folge} in eine sortierte Listen umordnen kann. Eine \emph{bitone
369 Folge} ist eine monoton steigende Folge gefolgt von einer monoton absteigenden
370 Folge, oder ein zyklischer Shift davon. Abbildung~\ref{fig:beispiel-biton}
371 zeigt die vier prinzipiellen Möglichkeiten die durch zyklische Shifts
372 entstehen können. Die wichtigsten Varianten für das \emph{bitone
373 Mergesort-Netzwerk} zeigen die Abbildungen~\ref{fig:beispiel-biton-0}
374 und~\ref{fig:beispiel-biton-1}. Sie erhält man, wenn man eine aufsteigend und
375 eine absteigend sortierte Liste aneinanderhängt. Bei den anderen beiden Formen
376 ist wichtig zu beachten, dass das letzte Element nicht größer
377 (Abbildung~\ref{fig:beispiel-biton-2}) bzw. kleiner
378 (Abbildung~\ref{fig:beispiel-biton-3}) als das erste Element der Folge sein
379 darf.
380
381 \begin{figure}
382   \centering
383   \subfigure[aufsteigend, absteigend]{\input{images/beispiel-biton-0.tex}\label{fig:beispiel-biton-0}}
384   \subfigure[absteigend, aufsteigend]{\input{images/beispiel-biton-1.tex}\label{fig:beispiel-biton-1}}
385   \subfigure[aufsteigend, absteigend, aufsteigend]{\input{images/beispiel-biton-2.tex}\label{fig:beispiel-biton-2}}
386   \subfigure[absteigend, aufsteigend, absteigend]{\input{images/beispiel-biton-3.tex}\label{fig:beispiel-biton-3}}
387   \caption{Beispiele bitoner Folgen.}
388   \label{fig:beispiel-biton}
389 \end{figure}
390
391 \begin{figure}
392   \centering
393   \subfigure[normal]{\input{images/bitonic-merge.tex}\label{fig:bitonic-merge-normal}}
394   \qquad
395   \subfigure[trichter]{\input{images/bitonic-merge-trichter.tex}\label{fig:bitonic-merge-tricheter}}
396   \caption{Schematischer Aufbau des bitonen Mischers: Jedes Element der
397   aufsteigenden Folge $u_0, u_1, \ldots$ wird mit dem entsprechenden Element
398   der absteigend sortierten Folge $v_0, v_1, \ldots$ verglichen. Die beiden
399   resultierenden Teilfolgen sind wiederum biton.}
400   \label{fig:bitonic-merge-schema}
401 \end{figure}
402
403 Der Mischer funktioniert folgendermaßen: Gegeben sind zwei Folgen mit je
404 ${m = \frac{n}{2}}$ Elementen, $U = \left(u_0, u_1, \ldots, u_{m-1}\right)$ und
405 $V = \left(v_0, v_1, \ldots, v_{m-1}\right)$. Die Folge $U$ sei aufsteigend
406 sortiert, die Folge $V$ sei absteigend sortiert:
407 \begin{eqnarray}
408  u_0 \leqq u_1 \leqq &\ldots& \leqq u_{m-1} \\
409  v_0 \geqq v_1 \geqq &\ldots& \geqq v_{m-1}
410 \end{eqnarray}
411 Im ersten Schritt werden nun jeweils die Elemente an den gleichen relativen
412 Positionen verglichen und ggf. vertauscht:
413 \begin{equation}
414 u_i \longleftrightarrow v_i, \quad 0 \leqq i < m
415 \end{equation}
416 Sei $j \in \{0 \ldots m\}$ der Index der ersten Elemente $u_j$ und $v_j$, die
417 durch den gemeinsamen Komparator vertauscht werden. Unter der Annahme, dass
418 Elemente nur vertauscht werden wenn, sie ungleich sind, muss ${u_j > v_j}$
419 gelten. Mit $u_j \leqq u_{j+1}$ und $v_j \geqq v_{j+1}$ folgt daraus $u_{j+1}
420 > v_{j+1}$. Es werden also alle Elemente $u_k$ und $v_k$ mit $k \geqq j$
421 vertauscht. $j = m$ bezeichnet den Fall, in dem das größte Element der
422 "`linken"' Folge, $u_{m-1}$, kleiner ist als das kleinste Element der
423 "`rechten"' Folge, $v_{m-1}$. Daraus folgt, dass das Resultat in zwei bitone
424 Folgen aufteilen lässt: Eine aufsteigende~/ absteigende Folge und eine
425 absteigende~/ aufsteigende Folge. Abbildung~\ref{fig:bitonic-merge-normal}
426 zeigt die Situationen vor und nach diesem Schritt des Mischers.
427
428 Um die Folge vollständig zu sortieren, müssen anschließend die beiden
429 resultierenden bitonen Folgen sortiert werden. Die geschieht ebenfalls
430 mithilfe des bitonen Mischers, mit zwei Instanzen von
431 $\operatorname{BM}(\frac{n}{2})$. Diese rekursive Definition endet mit dem
432 bitonen Mischer mit zwei Leitungen, $\operatorname{BM}(2)$, der als
433 Komparator-Netzwerk mit einem Komparator zwischen den beiden Leitungen
434 definiert ist.
435
436 Der bitonen Mischer kann auch zwei aufsteigende Folgen sortieren. Dazu ist
437 lediglich eine etwas modifizierte Vergleichs-Kaskade im ersten Schritt
438 notwendig. Die folgenden, kleineren Mischer erhalten als Eingabe wieder eine
439 „echte“ bitone Folge. Abbildung~\ref{fig:bitonic-merge-tricheter} zeigt das
440 Schema des bitonen Mischers für zwei aufsteigend sortierte Foglen. Durch das
441 Umdrehen einer Folge verändert sich das Muster der Komparatoren ein wenig:
442 Statt an eine Treppe erinnert das Muster nun an einen Trichter.
443
444 Da sich die Anzahl der Leitungen in jedem Rekursionsschritt halbiert, endet
445 die Rekursion nach $\log(n)$~Schritten. In jedem Rekursionsschritt werden
446 $\frac{n}{2}$~Komparatoren eingefügt, so dass der gesamte Mischer aus
447 $\frac{1}{2} n \log(n) = \mathcal{O}\left(n \log(n)\right)$~Komparatoren
448 besteht, die in $\log(n)$~Schichten angeordnet werden können.
449
450 \subsubsection{Das bitone Mergesort-Netzwerk}
451
452 Ebenso wie der bitone Mischer $\operatorname{BM}(n)$ ist auch das \emph{bitone
453 Mergesort-Netzwerk} $\operatorname{BS}(n)$ rekursiv definiert. Es setzt sich
454 zusammen aus zwei Instanzen des bitonen Mergesort-Netzwerks halber Größe,
455 $\operatorname{BS}(\frac{n}{2})$, für je die Hälfte der Eingänge, sowie dem
456 bitonen Mischer für $n$~Leitungen, $\operatorname{BM}(n)$. Das Rekursionsende
457 ist das bitone Mergesort-Netzwerk mit nur einer Leitung,
458 $\operatorname{BS}(1)$, welches als leeres Komparatornetzwerk definiert ist. 
459 Entsprechend sind die Komparatornetzwerke $\operatorname{BM}(2)$ und
460 $\operatorname{BS}(2)$ identisch.
461
462 Bei der Konstruktion kommt die trichterförmige Anordnung der Komparatoren
463 (Abbildung~\ref{fig:bitonic-merge-tricheter}) gelegen, weil so die beiden
464 rekursiven Sortiernetzwerke in die gleiche Richtung sortieren können und so
465 alle Komparatoren in die gleiche Richtung zeigen.
466
467 \begin{figure}
468   \begin{center}
469   \input{images/batcher-8.tex}
470   \end{center}
471   \caption{$\operatorname{BS}(8)$, Batchers {\em bitones Mergesort-Netzwerk}
472   für acht Eingänge. Markiert sind die beiden Instanzen von
473   $\operatorname{BS}(4)$ (rot), die beiden bitonen
474   Mischer~$\operatorname{BM}(4)$ (blau) und die Komparatoren, die im letzten
475   rekursiven Schritt hinzugefügt wurden (grün).}
476   \label{fig:bitonic-08}
477 \end{figure}
478
479 Das konkrete Netzwerk~$\operatorname{BS}(8)$ ist in
480 Abbildung~\ref{fig:bitonic-08} zu sehen. Eingezeichnet sind ebenfalls die
481 beiden Instanzen des Netzwerks~$\operatorname{BS}(4)$ (rot) sowie der bitone
482 Mischer~$\operatorname{BM}(8)$ (blau). Die trichterförmige Komparator-Kaskade,
483 die die bitone Eingabefolge in zwei bitone Ausgabefolgen transformiert, ist
484 grün hinterlegt.
485
486 Das \emph{bitone Mergesort-Netzwerk} $\operatorname{BS}(8)$ besteht aus
487 $\frac{1}{4} n \log(n) \log(n+1) = \mathcal{O}\left(n (log (n))^2\right)$
488 Komparatoren, die in $\frac{1}{2} \log(n) \log(n+1) = \mathcal{O}(\log(n))$
489 Schichten angeordnet sind.
490
491 %\begin{figure}
492 %\begin{center}
493 %\includegraphics[viewport=115 491 372 782,width=7.5cm]{images/sn-rekursiver-aufbau.pdf}
494 %\end{center}
495 %\caption{Rekursiver Aufbau von $S(n)$: Es besteht aus zwei Instanzen von
496 %$S(n/2)$ und dem Mischer $M(n)$.}
497 %\label{fig:bms_rekursiver_aufbau}
498 %\end{figure}
499
500 \subsection{Das Odd-Even-Mergesort-Netzwerk}
501
502 Obwohl der Name ähnlich klingt, haben das \emph{Odd-Even-Mergesort-Netzwerk}
503 (OES) und das \emph{Odd-Even-Transpositionsort-Netzwerk} (siehe
504 Abschnitt~\ref{sect:odd_even_transpositionsort}) wenig gemein. Vielmehr ist
505 OES dem \emph{bitonen Mergesort-Netzwerk}, das im vorherigen Abschnitt
506 vorgestellt wurde, ähnlich: Auch dieses Sortiernetzwerk ist von
507 \textit{Kenneth~E. Batcher} gefunden worden und ist ebenfalls in~\cite{B1968}
508 beschrieben und initial analysiert worden. Eine weitere Gemeinsamkeit besteht
509 darin, dass es ebenfalls rekursiv durch einen Mischer definiert ist.
510
511 \subsubsection{Der Odd-Even-Mischer}\label{sect:der_odd_even_mischer}
512
513 Der \emph{Odd-Even-Mischer} $\operatorname{OEM}(n,m)$ ist ein
514 Komperatornetzwerk, dass zwei sortierte Folgen mit $n$ beziehungsweise $m$
515 Elementen zu einer sortierten Ausgabefolge mit $N = n+m$~Elementen
516 zusammenfügen kann. Dabei kommt es mit weniger Vergleichen aus als der
517 \emph{bitone Mischer}, der im Abschnitt~\ref{sect:der_bitone_mischer}
518 vorgestellt wurde. Allerdings benötigt der \emph{Odd-Even-Mischer} unter
519 Umständen mehr Schichten als der \emph{bitone Mischer}.~\cite{KNUTH}
520
521 Der \emph{Odd-Even-Mischer} selbst ist ebenfalls rekursiv aufgebaut: Die
522 Eingabe für den Mischer mit $N = n + m$ Leitungen besteht aus den beiden
523 sortierten Folgen $U = \left(u_0, u_1, \ldots, u_{n-1}\right)$ und
524 $V = \left(v_0, v_1, \ldots, v_{m-1}\right)$. Die gesamte Eingabe sei
525 $W = \left(w_0, w_1, \ldots, w_{N-1}\right)$ mit:
526 \begin{equation}
527 w_i = \left\{ \begin{array}{ll}
528         u_i,     & i < n \\
529         v_{i-n}, & i \geqq n
530       \end{array} \right.,
531       \quad 0 \leqq i < N
532 \end{equation}
533
534 \begin{figure}
535   \begin{center}
536   \input{images/oe-merge.tex}
537   \end{center}
538   \caption{Schematischer Aufbau des {\em Odd-Even} Mischers. Im Vergleich zum
539   bitonen Mischer für Acht kommt dieses Schema mit einem Komparator weniger
540   aus. Der Effekt wird duch den rekursiven Aufbau noch verstärkt.}
541   \label{fig:oe-merge}
542 \end{figure}
543
544 Diese werden in insgesamt vier sortierte Folgen aufgeteilt, je eine Liste der
545 geraden Indizes und je eine Liste der ungeraden Indizes.
546 \begin{eqnarray}
547   U_{\textrm{gerade}}   &=& \left(u_0, u_2, u_4, \ldots\right) \\
548   U_{\textrm{ungerade}} &=& \left(u_1, u_3, u_5, \ldots\right) \\
549   V_{\textrm{gerade}}   &=& \left(v_0, v_2, u_4, \ldots\right) \\
550   V_{\textrm{ungerade}} &=& \left(v_1, v_3, u_5, \ldots\right)
551 \end{eqnarray}
552
553 Die geraden Folgen $U_{\textrm{gerade}}$ und $V_{\textrm{gerade}}$ bzw. die
554 ungeraden Folgen $U_{\textrm{ungerade}}$ und $V_{\textrm{ungerade}}$ werden
555 rekursiv von kleineren {\em Odd-Even-Mischern} zusammengefügt, so dass sich am
556 Ausgang der Mischer die Folgen
557 \begin{eqnarray}
558   W_{\textrm{gerade}}   &=& \left(w_0, w_2, w_4, \ldots\right) \\
559   W_{\textrm{ungerade}} &=& \left(w_1, w_3, w_5, \ldots\right)
560 \end{eqnarray}
561 ergeben.
562
563 Anschließend werden die Komparatoren zwischen benachbarten Leitungen
564 hinzugefügt,
565 \begin{equation}
566   w_{2i-1} \longleftrightarrow w_{2i}, \quad 1 \leqq i < \frac{N}{2}
567 \end{equation}
568 die die Folge~$W$ sortieren. Den schematischen Aufbau des {\em
569 Odd-Even-Mischers} zeigt Abbildung~\ref{fig:oe-merge}.
570
571 Leider bricht die Rekursion nicht so schön ab, wie das beim {\em bitonen
572 Mischer} der Fall gewesen ist. Insbesondere für ${n = m = 1}$ würde --
573 entsprechend der Konstruktionsvorschrift -- ein leeres Netzwerk entstehen, was
574 offensichtlich nicht korrekt wäre. Die Abbruchbedingungen für den rekursiven
575 Aufbau lauten:
576 \begin{itemize}
577   \item Falls ${n = 0}$ oder ${m = 0}$: Das Netzwerk ist leer.
578   \item Falls ${n = 1}$ und ${m = 1}$: Das Netzwerk besteht aus einem
579   einzelnen Komparator.
580 \end{itemize}
581
582 Dass die resultierende Folge sortiert ist, lässt sich mit dem
583 {\em 0-1-Prinzip} zeigen:
584 Da $U$ und $V$ sortiert sind, ist die Anzahl der Nullen in den geraden
585 Teilfolgen, $U_{\textrm{gerade}}$ bzw. $V_{\textrm{gerade}}$, größer oder
586 gleich der Anzahl der Nullen in den ungeraden Teilfolgen
587 $U_{\textrm{ungerade}}$ bzw. $V_{\textrm{ungerade}}$ --~die Einsen verhalten
588 sich entsprechend umgekehrt. Das trifft demnach auch auf die Folgen
589 $W_{\textrm{gerade}}$ und $W_{\textrm{ungerade}}$ entsprechend zu:
590 \begin{eqnarray}
591   \left|W_{\textrm{gerade}}\right|_0
592   &=& \left|U_{\textrm{gerade}}\right|_0
593     + \left|V_{\textrm{gerade}}\right|_0
594    =  \left\lceil \frac{1}{2} \left|U\right|_0 \right\rceil
595    +  \left\lceil \frac{1}{2} \left|V\right|_0 \right\rceil \\
596   \left|W_{\textrm{ungerade}}\right|_0
597   &=& \left|U_{\textrm{ungerade}}\right|_0
598     + \left|V_{\textrm{ungerade}}\right|_0
599    =  \left\lfloor \frac{1}{2} \left|U\right|_0 \right\rfloor
600    +  \left\lfloor \frac{1}{2} \left|V\right|_0 \right\rfloor
601 \end{eqnarray}
602 Daraus folgt, dass $W_{\textrm{gerade}}$ $0$, $1$ oder $2$ Nullen mehr enthält
603 als $W_{\textrm{ungerade}}$. In den ersten beiden Fällen ist die "`verzahnte"'
604 Ausgabe der beiden kleineren Mischer bereits sortiert. Nur im letzten Fall,
605 wenn $W_{\textrm{gerade}}$ zwei Nullen mehr enthählt als
606 $W_{\textrm{ungerade}}$, muss genau eine Vertauschung stattfinden, um die
607 Ausgabe zu sortieren. Diese wird von den Komparatoren, die benachbarte
608 Leitungen miteinander vergleichen, ausgeführt. Die jeweiligen Situationen sind
609 in Abbildung~\ref{fig:oe-post-recursive} dargestellt.
610
611 \begin{figure}
612   \centering
613   \subfigure[$\left|W_{\textrm{gerade}}\right|_0 - \left|W_{\textrm{ungerade}}\right|_0 = 0$]{\input{images/oe-post-recursive-diff0.tex}}
614   \qquad
615   \subfigure[$\left|W_{\textrm{gerade}}\right|_0 - \left|W_{\textrm{ungerade}}\right|_0 = 1$]{\input{images/oe-post-recursive-diff1.tex}}
616   \qquad
617   \subfigure[$\left|W_{\textrm{gerade}}\right|_0 - \left|W_{\textrm{ungerade}}\right|_0 = 2$]{\input{images/oe-post-recursive-diff2.tex}}
618   \caption{Die drei Situationen, die nach dem Verzahnen der Ausgaben der
619   kleineren {\em Odd-Even-Mischer} entstehen können. Ist die Differenz der
620   Anzahl der Nullen gleich $0$ oder $1$, ist die Folge bereits sortiert. Im
621   letzten Fall stellt einer der Komparatoren sicher, dass das Ergebnis
622   sortiert ist.}
623   \label{fig:oe-post-recursive}
624 \end{figure}
625
626 Da die Teilfolgen $U$ und $V$ in jedem Rekursionsschritt etwa halbiert werden,
627 bricht die Rekursion nach $\mathcal{O}\left(\log (n) + \log (m)\right)$
628 Schritten ab. Die exakte Anzahl der benötigten Rekursionsschritte (und damit
629 Schichten im Mischer-Netzwerk), hängt von der Längeren der beiden
630 Eingabefolgen ab und beträgt $1 + \lceil \log\left(\max(n, m)\right) \rceil$.
631
632 Die Anzahl der Komparatoren $K(n,m)$, die $\operatorname{OEM}(n,m)$ im
633 allgemeinen Fall verwendet, ist Gemäß der rekursiven Definition in
634 Abhängigkeit der Länge der Eingabefolgen, $n$ und $m$:
635 \begin{displaymath}
636   K(n,m) = \left\{ \begin{array}{ll}
637     nm, & \mathrm{falls} \quad nm \leqq 1 \\
638     K\left(\left\lceil \frac{n}{2} \right\rceil, \left\lceil \frac{m}{2} \right\rceil\right)
639     + K\left(\left\lfloor \frac{n}{2} \right\rfloor, \left\lfloor \frac{m}{2} \right\rfloor\right)
640     + \left\lfloor \frac{1}{2} (m + n - 1) \right\rfloor & \mathrm{falls} \quad nm > 1
641   \end{array} \right.
642 \end{displaymath}
643 Leider ist es schwierig, diese allgemeine Formel in einer geschlossenen Form
644 anzugeben. Aus der Anzahl der Rekursionsschritte ist jedoch leicht erkennbar,
645 dass $K(n,m)$ in $\mathcal{O}(N \log (N))$ enthalten ist.
646
647 Für den wichtigen Spezialfall, dass $n = m = 2^{t-1}$, lässt sich die Anzahl
648 der Komparatoren im Vergleich zum \emph{bitonen Mischer} angeben: Der erste
649 Rekursionsschritt der OEM-Konstruktion fügt
650 $\left\lfloor \frac{1}{2} (m + n - 1) \right\rfloor = \frac{N}{2} - 1$
651 Komparatoren ein -- einen Komparator weniger als der \emph{bitone Mischer} in
652 diesem Schritt. Das selbe gilt für die rekursiv verwendeten kleineren Mischer,
653 $\operatorname{OEM}(\frac{n}{2}, \frac{n}{2})$ und so weiter bis
654 einschließlich $\operatorname{OEM}(2, 2)$, von denen es $2, 4, \dots,
655 \frac{N}{4} = 2^{\log(N)-2}$ Instanzen gibt. Insgesamt werden
656 \begin{displaymath}
657   \sum_{i=0}^{\log(N)-2} 2^i = 2^{\log(N) - 1} - 1 = \frac{N}{2} - 1 = n - 1
658 \end{displaymath}
659 Komparatoren eingespart. Damit ergibt sich
660 \begin{displaymath}
661   K\left(n = 2^{t-1}, n = 2^{t-1}\right) = \frac{1}{2} N \log(N) - \frac{N}{2} + 1
662 \end{displaymath}
663 für die Anzahl der Komparatoren, die von $\operatorname{OEM}(N = 2^t)$
664 benötigt werden.
665
666 \subsubsection{Das Odd-Even-Mergesort-Netzwerk}
667
668 Das \emph{Odd-Even-Mergesort-Netzwerk} $\operatorname{OES}(n)$ besteht --~wie
669 das \emph{bitone Mergesort-Netzwerk}~-- rekursiv aus kleineren Varianten von
670 sich selbst und einem abschließenden \emph{Odd-Even-Mischer}. Die
671 effizientesten Sortiernetzwerke in Bezuf auf Komparator- und Schichtzahl
672 entstehen, wenn die Anzahl der Leitungen jeweils halbiert wird. Somit besteht
673 $\operatorname{OES}(n)$ aus
674 $\operatorname{OES}\left(\left\lceil\frac{n}{2}\right\rceil\right)$,
675 $\operatorname{OES}\left(\left\lfloor\frac{n}{2}\right\rfloor\right)$
676 und $\operatorname{OEM}\left(\left\lceil\frac{n}{2}\right\rceil,
677 \left\lfloor\frac{n}{2}\right\rfloor\right)$. Die Rekursion endet mit
678 $\operatorname{OES}(1)$ und $\operatorname{OES}(0)$, die als leere
679 Komparatornetzwerke definiert sind.
680
681 \begin{figure}
682   \begin{center}
683   \input{images/oe-mergesort-8.tex}
684   \end{center}
685   \caption{Das {\em Odd-Even-Mergesort-Netzwerk} für acht Eingänge. Markiert
686   sind die Instanzen von $\operatorname{OES}(4)$ (rot), die beiden
687   \emph{Odd-Even-Mischer} $\operatorname{OEM}(4)$ für gerade und ungerade
688   Leitungen (blau) und die im ersten Rekursionsschritt hinzugefügten
689   Komparatoren zwischen benachbarten Leitungen (grün).}
690   \label{fig:odd-even-mergesort-08}
691 \end{figure}
692
693 In Abbildung~\ref{fig:odd-even-mergesort-08} ist das konkrete Sortiernetzwerk
694 $\operatorname{OES}(8)$ zu sehen. Rot markiert sind die beiden rekursiven
695 Instanzen $\operatorname{OES}(4)$. Die blauen und der grüne Block stellen den
696 \emph{Odd-Even-Mischer} für acht Leitungen dar: Die beiden blauen Blöcke sind
697 die rekursiven Instanzen von $\operatorname{OEM}(4)$, der grüne Block markiert
698 die Komparatoren, die in ersten Rekursionsschritt hinzugefügt werden.
699
700 Im Allgemeinen ist die Anzahl der Komparatoren, die vom
701 \emph{Odd-Even-Mergesort-Netzwerk} verwendet wird, $k(n)$, direkt aus der
702 Definition beziehungsweise der Konstruktionsanleitung abzulesen:
703 \begin{displaymath}
704   k(n) = k\left(\left\lceil\frac{n}{2}\right\rceil\right)
705        + k\left(\left\lfloor\frac{n}{2}\right\rfloor\right)
706        + K\left(\left\lceil\frac{n}{2}\right\rceil, \left\lfloor\frac{n}{2}\right\rfloor\right)
707 \end{displaymath}
708 Eine geschlossene Form dieser Formel ist schon alleine deshalb schwierig, weil
709 sie für $K(n,m)$ schwierig anzugeben ist. Es ist allerdings bekannt, dass
710 $k(n)$ in $\mathcal{O}\left(n \left(\log (n)\right)^2\right)$ enthalten ist.
711
712 Für den wichtigen Spezialfall, dass $n = 2^t$ eine Zweierpotenz ist, kann die
713 Anzahl der Komparatoren wieder explizit angegeben werden. \textit{Kenneth
714 Batcher} zeigt in~\cite{B1968}, dass in diesem Fall
715 \begin{displaymath}
716   k(n = 2^t) = \frac{1}{4} n \left(\log (n)\right)^2 - \frac{1}{4}n\log(n) + n - 1
717 \end{displaymath}
718 gilt.
719
720 % gnuplot:
721 % oem(n,m) = ((n*m) <= 1) ? (n*m) : oem(ceil(.5*n), ceil(.5*m)) + oem(floor(.5*n), floor(.5*m)) + floor(.5*(n+m-1.0))
722 % oem1(n) = oem(ceil(.5*n),floor(.5*n))
723 % oes(n) = (n <= 1.0) ? 0 : oes(ceil(0.5*n)) + oes(floor(0.5*n)) + oem1(n)
724
725 %\begin{itemize}
726 %\item Pairwise sorting-network
727 %\end{itemize}
728
729 \newpage
730 \section{Transformation von Sortiernetzwerken}
731
732 \subsection{Komprimieren}
733
734 \todo{Aus theoretischer Sicht eigentlich eine Trivialität. Rausschmeißen?}
735
736 Komparatoren, die unterschiedliche Leitungen miteinander vergleichen, können
737 gleichzeitig ausgewertet werden, wie bereits in
738 Abschnitt~\ref{sect:einleitung_sortiernetzwerke} beschrieben. Unter
739 \emph{Komprimieren} wird eine (Neu-)Gruppierung in die kleinstmögliche Anzahl
740 von \emph{Schichten} verstanden.
741
742 Diese Anzahl ist insbesondere beim automatisierten Bewerten von
743 Komparatornetzwerken interessant. \dots
744
745 \subsection{Normalisieren}
746
747 \begin{figure}
748   \centering
749   \subfigure[$S(8)$ (nach Konstruktion)]{\input{images/batcher-8-nonstd.tex}\label{fig:bitonic-nonstd}}
750   \subfigure[$S(8)$ (normalisiert)]{\input{images/batcher-8-std.tex}\label{fig:bitonic-std}}
751   \caption{Jedes Sortiernetzwerk kann in ein Standard-Sortiernetzwerk
752   transformiert werden. Gezeigt ist das bitone Sortiernetzwerk nach der
753   intuitiven Konstruktion und die normalisierte Variante.}
754   \label{fig:beispiel_normalisieren}
755 \end{figure}
756
757 Ein \emph{Standard-Sortiernetzwerk} oder \emph{normalisiertes Sortiernetzwerk}
758 ist ein Sortiernetzwerk, dessen Komparatoren alle in die selbe Richtung
759 zeigen. Jedes Sortiernetzwerk kann in eine normaliesierte Variante
760 transformiert werden. Dazu gibt beispielsweise \emph{Knuth} (\todo{Verweis})
761 einen Algorithmus an.
762
763 Abbildung~\ref{fig:beispiel_normalisieren} zeigt das das
764 bitone Sortiernetzwerk in zwei Varianten. Abbildung~\ref{fig:bitonic-nonstd}
765 zeigt das Netzwerk nach der Konstruktionsvorschrift, siehe auch
766 Abbildung~\ref{fig:bitonic-merge-normal}: In den ersten drei Schichten werden
767 die unter und die obere Hälfte gegenläufig sortiert. Das heißt dass nach drei
768 Schritten die eine Hälfte auf- und die andere Hälfte absteigend sortiert ist. 
769 In den Schichten~4 bis~6 folgt der bitone Mischer entsprechend der rekursiven
770 Definition.
771
772 In Abbildung~\ref{fig:bitonic-std} ist die normalisierte Version des bitonen
773 Mergesort-Netzwerks zu sehen. Alle Komparatoren zeigen hier in die gleiche
774 Richtung. Statt dem typischen "`Treppenmuster"' sind abwechselnd das Treppen-
775 und das Trichtermuster zu sehen.
776
777 \subsection{Zwei Netzwerke kombinieren}
778
779 Um Sortiernetzwerke als \emph{Individuen} evolutionärer Algorithmen verwenden
780 zu können, muss es möglich sein, zwei Sortiernetzwerke zu einem neuen
781 Sortiernetzwerk zusammenzufassen.
782
783 Wir haben diese Technik in den vorangegangen Abschnitten bereits verwendet,
784 beispielsweise um zwei \emph{bitone Mergesort-Netzwerke} mit jeweils der
785 halben Leitungszahl, $\operatorname{BS}\left(\frac{n}{2}\right)$, zu einem
786 einzigen Sortiernetzwerk $\operatorname{BS}(n)$ zu kombinieren. Auch das
787 \emph{Odd-Even-Mergesort-Netzwerk} $\operatorname{OES}(n)$ wurde auf diese Art
788 und Weise rekursiv aufgebaut.
789
790 Die vorgestellten \emph{Mischer} erwarten als Eingabe zwei bereits sortierte
791 Folgen. \emph{Wie} diese Folgen sortiert wurden, ist unerheblich. Entsprechend
792 können wir beliebige Sortiernetzwerke einsetzen, um die beiden Eingabefolgen
793 zu sortieren, und die Ausgaben mit einem der beschriebenen Mischer
794 zusammenfügen.
795
796 Beispielsweise kann man die Ausgabe von zwei \emph{bitonen
797 Mergesort-Netzwerken} $\operatorname{BS}(8)$ mit je acht Leitungen mit dem
798 \emph{Odd-Even-Merge} $\operatorname{OEM(8,8)}$ zu einer sortierten
799 Gesamtfolge zusammenfügen. Das resultierende Sortiernetzwerk besitzt
800 73~Komparatoren (zum Vergleich: $\operatorname{BS}(16)$ benötigt
801 80~Komparatoren, $\operatorname{OES}(16)$ nur 63).
802
803 Verbesserungen in der Anzahl der benötigten Komparatoren beziehungsweise der
804 Schichten eines „kleinen“ Sortiernetzwerks übertragen sich direkt auf das
805 resultierende Gesamtnetzwerk. Das \emph{Odd-Even-Mergesort-Netzwerk}
806 $\operatorname{OES}(9)$ benötigt beispielsweise 26~Komparatoren, die in in
807 neun Schichten angeordnet sind. Es sind allerdings Sortiernetzwerke mit neun
808 Eingängen bekannt, die lediglich 25~Komparatoren in sieben Schichten
809 benötigen. Kombiniert man zwei dieser Netzwerke mit dem
810 \emph{Odd-Even-Mischer} erhält man ein Sortiernetzwerk mit 18~Eingängen, das
811 80~Komparatoren in 11~Schichten benötigt -- $\operatorname{OES}(18)$ benötigt
812 82~Komparatoren in 13~Schichten. Damit ist das resultierende Netzwerk so
813 schnell wie das Sortiernetzwerk mit 18~Eingängen, das \textit{Sherenaz~W.
814 Al-Haj Baddar} und \textit{Kenneth~E. Batcher} in ihrer Arbeit „An 11-Step
815 Sorting Network for 18~Elements“~\cite{BB2009} vorstellen, benötigt aber
816 6~Komparatoren weniger.
817
818 % 9   9
819 % 9  18
820 % 9  27
821 % 9  36
822 % 9  45
823 % 8  53
824 % 8  61
825 % 7  68
826 % 7  75
827 % 6  81
828 % 5  86
829
830 Das Zusammenfassen von zwei Sortiernetzwerken durch Hintereinanderausführung
831 ist nicht sinnvoll: Da die Ausgabe des ersten Sortiernetzwerks bereits
832 sortiert ist, ist das zweite Sortiernetzwerk überflüssig. Eine
833 Aneinanderreihung der Art „die ersten $x$~Schichten des einen, dann die
834 letzten $y$~Schichten des anderen Sortiernetzwerks“ zerstören im Allgemeinen
835 die Sortiereigenschaft. Die Sortiereigenschaft des resultierenden
836 Komparatornetzwerks müsste überprüft werden, was nach heutigem Wissensstand
837 nur mit exponentiellem Aufwand möglich ist.
838
839 %\begin{itemize}
840 %\item Mit dem Bitonic-Merge
841 %\item Mit dem Odd-Even-Merge
842 %\item Nach dem Pairwise sorting-network Schema.
843 %\end{itemize}
844
845 \subsection{Leitungen entfernen}\label{sect:leitungen_entfernen}
846
847 Im vorherigen Abschnitt haben wir gesehen, dass es mithilfe von
848 \emph{Mischern} möglich ist, aus zwei Sortiernetzwerken mit je $n$~Eingängen
849 ein neues Sortiernetzwerk mit $2n$~Eingängen zu erzeugen. Für einen
850 beabsichtigen \emph{evolutionären Algorithmus} ist es jedoch notwendig, dass
851 sich die Anzahl der Eingänge nicht verändert. Das heißt, dass wir wieder ein
852 Sortiernetzwerk mit $n$~Eingängen erhalten müssen.
853
854 Man kann ein gegebenes Sortiernetzwerk mit $n$~Eingängen auf ein
855 Sortiernetzwerk mit ${n-1}$~Leitungen verkleinern, indem man eine Leitung
856 „eliminiert“. Dazu nehmen wir an, dass das Minimum oder das Maximum an einem
857 bestimmten Eingang anliegt. Der Weg, den das Minimum beziehungsweise das Maxim
858 durch das Sortiernetzwerk nimmt, ist eindeutig bestimmt und endet an einem der
859 „Ränder“, also auf der Leitung mit dem höchsten oder dem niedrigsten Index.
860 Insbesondere ist bekannt, welche Komparatoren „berührt“ werden und welche
861 dafür sorgen, dass der Wert die Leitung gewechselt, da das Minimum jeden
862 Vergleich „verliert“ und das Maximum jeden Vergleich „gewinnt“. Die
863 Abbildung~\ref{fig:oe-transposition-cut0} zeigt den Weg eines Maximums durch
864 das {\em Odd-Even-Transpositionsort-Netzwerk}.
865
866 \begin{figure}
867   \centering
868   \subfigure[foo]{\input{images/oe-transposition-cut0.tex}\label{fig:oe-transposition-cut0}}
869   \subfigure[bar]{\input{images/oe-transposition-cut1.tex}\label{fig:oe-transposition-cut1}}
870   \subfigure[baz]{\input{images/oe-transposition-cut2.tex}\label{fig:oe-transposition-cut2}}
871   \subfigure[qux]{\input{images/oe-transposition-cut3.tex}\label{fig:oe-transposition-cut3}}
872   \caption{Eine Leitung wird aus dem
873   \emph{Odd-Even-Transpositionsort}-Netzwerk $\operatorname{OET}(8)$ entfernt:
874   Auf der rot markierten Leitung wird $\infty$ angelegt. Da der Wert bei jedem
875   Komparator am unteren Ende herauskommt, ist der Pfad fest vorgegeben. Da die
876   restlichen Werte trotzdem noch richtig sortiert werden müssen, kann dieser
877   Pfad herausgetrennt werden. In der letzten Abbildung ist
878   $\operatorname{OET}(7)$ markiert.}
879   \label{fig:oe-transposition-cut}
880 \end{figure}
881
882 Im nächsten Schritt werden alle beteiligten Komparatoren gelöscht bzw.
883 ersetzt: Komparatoren, die {\em nicht} zu einem Wechsel der Leitung geführt
884 haben, werden ersatzlos gelöscht. Diese Komparatoren sind in
885 Abbildung~\ref{fig:oe-transposition-cut0} grün markiert. Die Komparatoren, die
886 zum Wechsel der Leitung geführt haben, werden durch sich kreuzende Leitungen
887 ersetzt. Das Resultat ist eine Leitung, auf der das Minimum beziehungsweise
888 das Maximum angenommen wird, die an unterster oder oberster Stelle endet und
889 auf die keine Komparatoren mehr berührt
890 (Abbildung~\ref{fig:oe-transposition-cut1}).
891
892 Die Werte auf den verbleibenden $(n-1)$~Leitungen müssen vom restlichen
893 Komparatornetzwerk immernoch sortiert werden: Wir haben lediglich die Position
894 des Minimums oder des Maximums angenommen. Ein Sortiernetzwerk muss die
895 Eingabe sortieren, egal auf welcher Leitung das Minimum~/ das Maximum liegt.
896 Wir haben lediglich angefangen, das Sortiernetzwerk unter diese Annahme
897 auszuwerten -- über die verbleibenden Eingänge haben wir keine Aussage
898 getroffen. Entsprechend müssen die verbleibenden Ausgänge eine sortierte Liste
899 mit $(n-1)$~Elementen darstellen.
900
901 Wenn wir die Minimum- beziehungsweise Maximum-Leitung entfernen
902 (Abbildung~\ref{fig:oe-transposition-cut2}), bleibt das Sortiernetzwerk für
903 $(n-1)$~Leitungen übrig. Je nachdem, ob auf einer Leitung ein Minimum oder ein
904 Maximum angenommen wird, bezeichnen wir das eliminieren einer Leitung als
905 \emph{Minimum-Schnitt} beziehungsweise \emph{Maximum-Schnitt}.
906
907 Die letzte Abbildung, \ref{fig:oe-transposition-cut3}, zeigt das
908 Sortiernetzwerk wieder mit den üblichen geraden Leitungen und die rot
909 markierten Komparatoren wurden verschoben, so dass sich eine kompaktere
910 Darstellung ergibt. Ausserdem ist das
911 {\em Odd-Even-Transpositionsort-Netzwerk} für sieben Werte markiert. Der
912 zusätzliche Komparator vor dem $\textrm{OET}(7)$ hat keinen Einfluss auf die
913 Ausgabe und kann entfernt werden.
914
915 \subsubsection{Anzahl möglicher und unterschiedlicher Schnittmuster}
916 \label{sect:anzahl_schnittmuster}
917
918 Der Eliminierungsschritt kann iterativ angewandt werden, um aus einem
919 Sortiernetzwerk mit $n$~Ein\-gängen Sortiernetzwerke mit $n-1$, $n-2$,
920 $n-3$,~\dots Eingängen zu erzeugen. Insbesondere können auf diese Art und
921 Weise einen Sortiernetzwerke mit $2n$~Eingängen wieder auf Sortiernetzwerke
922 mit $n$~Eingängen reduziert werden. $k$~Minimum- und Maximum-Schnitte, die
923 nacheinander angewendet ein $n$-Sortiernetzwerk auf ein
924 ${(n-k)}$-Sortiernetz\-werk reduzieren, bezeichnen wir als
925 \emph{$k$-Schnittmuster}.
926
927 Zwei Schnittmuster heißen \emph{äquivalent} bezüglich~$S$, wenn ihre Anwendung
928 auf das Sortiernetzwerk~$S$ das selbe Ergebnis liefert. Ansonsten heißen die
929 Schnittmuster \emph{unterschiedlich} bezüglich~$S$. 
930
931 Bei einem Sortiernetzwerk mit $n$~Eingängen gibt es $2n$~Möglichkeiten eine
932 Leitung zu entfernen: Auf jeder der $n$~Leitungen kann sowohl das Minimum als
933 auch das Maximum angenommen werden. Wendet man das Verfahren iterativ an, um
934 ein $n$-Sortiernetzwerk auf ein ${(n-k)}$-Sortiernetzwerk zu reduzieren,
935 ergeben sich insgesamt
936 \begin{equation}\label{eqn:anzahl_schnittmuster}
937   \prod_{i=n}^{1+n-k} 2i = 2^k \frac{n!}{(n-k)!}
938   \quad (n > m)
939 \end{equation}
940 \emph{mögliche} Schnittmuster. Diese Schnittmuster sind nicht alle
941 unterschiedlich. Legt man beispielsweise das Minimum auf die unterste Leitung
942 und das Maximum auf die oberste Leitung eines Standard-Sortiernetzwerks,
943 führen beide Reihenfolgen zum selben Ergebnis.
944
945 \textit{Moritz Mühlenthaler} zeigt in seiner Arbeit (\todo{Referenz}), dass es
946 möglich ist, mehrere Eingänge gleichzeitig mit Minimum beziehungsweise Maximum
947 vorzubelegen. Dadurch wird die Anzahl der möglichen Schnittmuster reduziert,
948 die Menge der so erzeugbaren Sortiernetzwerke bleibt aber unverändert. Die
949 Anzahl der möglichen Schnittmuster setzt sich zusammen aus der Anzahl von
950 Möglichkeiten, $k$~Leitungen aus $n$~Leitungen auszuwählen, und die möglichen
951 Minimum-~/ Maximum-Muster. Damit ergibt sich folgende Formel für die Anzahl
952 der möglichen Schnittmuster:
953 \begin{displaymath}
954   2^k \cdot \left( \begin{array}{c} n \\ k \end{array} \right)
955   = 2^{k} \cdot \frac{n!}{k! (n-k)!}
956   = 2^{k} \cdot \frac{n!}{(n-k)!} \cdot \frac{1}{k!}
957   \quad (1 \leqq k < n)
958 \end{displaymath}
959
960 Die Anzahl der möglichen Schnittmuster wird mit der Anzahl der zu entfernenden
961 Leitungen sehr schnell sehr groß. Um ein Sortiernetzwerk mit 32~Eingängen auf
962 ein Sortiernetzwerk mit 16~Eingängen zu reduzieren, ist ein Schmittmuster mit
963 16~Schnitten notwendig, für das es bereits etwa ${3,939 \cdot 10^{13}}$
964 Möglichkeiten gibt. Ein Ausprobieren aller Möglichkeiten ist für große
965 Netzwerke nicht oder nur unter erheblichem Ressourcenaufwand möglich.
966
967 Die Anzahl der \emph{unterschiedlichen} Schnittmuster ist allerdings kleiner
968 als die Anzahl der möglichen Schnittmuster. Für jeden Komparator auf der
969 ersten Stufe gibt es neun verschiedene Eingangskonfigurationen: Für beide
970 Eingänge gibt es drei mögliche Eingangswerte, Minimum, Maximum und
971 unspezifiziert. Es gibt drei Konfigurationen, bei denen an beiden Eingängen
972 der gleiche Wert angelegt wird, und sechs Konfigurationen, bei denen sich die
973 Werte unterscheiden.
974
975 Bei diesen letzten sechs Konfigurationen werden je zwei auf das selbe
976 Ausgangmuster abgebildet, weil die Position des Minimums beziehungsweise des
977 Maximums durch den Komparator vorgegeben wird. Das heißt, dass die neun
978 unterschiedlichen Eingangsmuster nur sechs unterschiedliche Ausgangsmuster
979 erzeugen. In der zweiten und allen folgenden Schichten kann man diesen
980 Unterschied nicht mehr erkennen. In allen sechs Fällen, in denen sich die
981 Eingänge unterscheiden, wird anschließend der Komparator entfernt, so dass
982 sich die Resultate auch in der ersten Schicht nicht unterscheiden.
983
984 \begin{figure}
985   \begin{center}
986     \includegraphics[viewport=0 0 360 216,width=15cm]{images/count-cuts-16.pdf}
987   \end{center}
988   \caption{Anzahl der \emph{unterschiedlichen} Sortiernetzwerke, die durch
989   8-Schnittmuster aus $\operatorname{OES}(16)$, $\operatorname{BS}(16)$ und
990   $\operatorname{PS}(16)$ hervorgegangen sind. Die Anzahl der
991   unterschiedlichen Netzwerke nach $10^6$~Iterationen ist 3519 für das
992   \emph{Odd-Even-Mergesort-Netzwerk}, 4973 für das \emph{bitone
993   Mergesort-Netzwerk} und 18764 für das \emph{Pairwise-Sorting-Netzwerk}.}
994   \label{fig:count-cuts-16}
995 \end{figure}
996
997 Alleine durch Betrachten der ersten Schicht von Komparatoren konnte die Anzahl
998 der \emph{unterschiedlichen} Schnittmuster auf höchstens $\frac{2}{3}$ der
999 \emph{möglichen} Schnittmuster reduziert werden. Um die Anzahl der
1000 \emph{unterschiedlichen} Schnittmuster experimentell zu ermitteln, wurden je
1001 eine Million zufällige 8-Schnittmuster auf die 16-Sortiernetzwerke
1002 $\operatorname{OES}(16)$, $\operatorname{BS}(16)$ und $\operatorname{PS}(16)$
1003 angewandt. Anschließend wurde mithilfe einer Hashtabelle überprüft, ob das
1004 resultierende Sortiernetzwerk schon von einem \emph{äquivalenten}
1005 Schnittmuster erzeugt wurde. Falls das Sortiernetzwerk noch nicht in der
1006 Hashtabelle enthalten war, wurde der Zähler für unterschiedliche Schnittmuster
1007 erhöht und das Sortiernetzwerk eingefügt.
1008
1009 Abbildung~\ref{fig:count-cuts-16} trägt die Anzahl der
1010 \emph{unterschiedlichen} Schnittmuster gegen die Anzahl der zufälligen
1011 Schnittmuster auf. Klar zu sehen ist, dass sich die Anzahl der erzeugten
1012 Sortiernetzwerke nach $500.000$~Iterationen nur noch gering verändert und der
1013 Wert nach $1.000.000$~Iterationen allem Anschein nach dem Endwert schon sehr
1014 nahe ist.
1015
1016 Die Anzahl der möglichen 8-Schnittmuster ist entsprechend der
1017 Formel~\ref{eqn:anzahl_schnittmuster} 3.294.720. Diese möglichen Schnittmuster
1018 führen aber nur zu wenigen \emph{unterschiedlichen} Sortiernetzwerken: 3519
1019 ($\approx 0,1\%$) im Fall des \emph{Odd-Even-Mergesort-Netzwerks}, 4973
1020 ($\approx 0,15\%$) beim \emph{bitonen Mergesort-Netzwerk} und 18764 ($\approx
1021 0,57\%$) beim \emph{Pairwise-Sorting-Netzwerk}. Zwar ist es möglich, dass mehr
1022 Iterationen die Anzahl der unterschiedlichen Schnittmuster noch wachsen lässt.
1023 Die Graphen in Abbildung~\ref{fig:count-cuts-16} geben jedoch Grund zu der
1024 Annahme, dass die Anzahl dieser zusätzlichen, unterschiedlichen Schnittmuster
1025 vernachlässigbar klein ist.
1026
1027 Bedingt durch die sehr große Anzahl möglicher Schnittmuster ist dieses
1028 Experiment für größere Sortiernetzwerke leider nicht sinnvoll durchführbar.
1029 Die Hashtabelle benötigt mehr Arbeitsspeicher als in derzeitigen Rechnern
1030 vorhanden ist, bevor ein entsprechender Graph den linearen Bereich für
1031 „kleine“ x-Werte verlässt.
1032
1033 Um die Anzahl der unterschiedlichen Schnittmuster trotzdem abschätzen zu
1034 können, kann man sich einer stochastischen Methode bedienen, der sogenannten
1035 \emph{Monte-Carlo-Methode}. Zunächst generiert man eine Menge~$S$ von
1036 $k$~unterschiedlichen Schnittmustern. Anschließend werden $n$~Schnittmuster
1037 zufällig erzeugt und überprüft, ob sie sich in der Menge~$S$ enthalten sind.
1038 Unter der Annahme, dass das Verhältnis der zufälligen Schnittmuster, die in
1039 $S$ enthalten sind, und $n$ dem Verhältnis von $k$ und der Anzahl der
1040 unterschiedlichen Schnittmuster ingesamt entspricht, kann man die Anzahl der
1041 unterschiedlichen Schnittmuster abschätzen.
1042
1043 \begin{figure}
1044   \begin{center}
1045     \includegraphics[viewport=0 0 425 262,width=15cm]{images/collisions-10000-1000000-32.pdf}
1046   \end{center}
1047   \caption{Abschnätzung der unterschiedlichen Schnittmuster mit der
1048   \emph{Monte-Carlo-Methode} für $\operatorname{OES}(32)$ und
1049   $\operatorname{BS}(32)$.}
1050   \label{fig:collisions-10000-1000000-32}
1051 \end{figure}
1052
1053 In Abbildung~\ref{fig:collisions-10000-1000000-32} ist das Ergebnis des
1054 Monte-Carlo-Algorithmus für 16-Schnittmuster zu sehen, die auf
1055 $\operatorname{OES}(32)$ und $\operatorname{BS}(32)$ angewandt wurden: Von
1056 jedem Sortiernetzwerk wurden zunächst eine Menge~$S$ von 10.000
1057 \emph{unterschiedlichen} Schnittmustern erzeugt. Anschließend wurden 1.000.000
1058 zufällige Schnittmuster erzeugt und der Anteil der zufälligen Schnittmuster,
1059 die \emph{äquivalent} zu einem in~$S$ enthalten Schnittmuster sind, berechnet.
1060 Für $\operatorname{OES}(32)$ war dieser Anteil etwa $0,19 \%$, für
1061 $\operatorname{BS}(32)$ etwa $0,29 \%$. Das ergibt eine Abschätzung von $5,2
1062 \cdot 10^6$ unterschiedlichen Schnittmustern für $\operatorname{OES}(32)$ und
1063 $3,4 \cdot 10^6$ für $\operatorname{BS}(32)$.
1064
1065 \begin{figure}
1066   \begin{center}
1067     \includegraphics[viewport=0 0 425 262,width=15cm]{images/collisions-100000-1000000-32-ps.pdf}
1068   \end{center}
1069   \caption{Abschnätzung der unterschiedlichen Schnittmuster mit der
1070   \emph{Monte-Carlo-Methode} für $\operatorname{PS}(32)$. 385 von 1.000.000
1071   zufälligen Schnittmustern waren äquivalent zu einem Schnittmuster in einer
1072   Menge von 100.000. Daraus ergibt sich eine Schätzung von $2,6 \cdot 10^8$
1073   unterschiedlichen Schnittmustern.}
1074   \label{fig:collisions-100000-1000000-32-ps}
1075 \end{figure}
1076
1077 Im vorherigen Abschnitt wurde das \emph{Pairwise-Sorting-Netzwerk}
1078 $\operatorname{PS}(32)$ nicht betrachtet, da es für dieses Netzwerk viel mehr
1079 unterschiedliche 16-Schnittmuster gibt als für $\operatorname{OES}(32)$ und
1080 $\operatorname{BS}(32)$. In Anbetracht der Tatsache, dass die Anzahl der
1081 unterschiedlichen 8-Schnittmuster für $\operatorname{PS}(16)$ in
1082 Abbildung~\ref{fig:count-cuts-16} bereits mehr als dreimal größer war als die
1083 Anzahl für $\operatorname{OES}(16)$ beziehungsweise $\operatorname{BS}(16)$,
1084 ist dieser Umstand wenig verwunderlich. In einem kombinierten Graphen hätte
1085 man keine Details mehr erkennen können. Aufgrund der hohen Anzahl
1086 unterschiedlicher Schnittmuster, wurde für das gleiche Experiment mit
1087 $\operatorname{PS}(32)$ eine initiale Menge von 100.000 unterschiedilchen
1088 Schnittmustern erzeugt. Trotzdem wurden nach 1.000.000 Iterationen nur 385
1089 Schnittmuster gefunden, die zu einem Schnittmuster in der Menge äquivalent
1090 sind. Daraus ergibt sich eine Abschätzung von $2,6 \cdot 10^8$
1091 unterschiedlichen Schnittmustern -- zwei Zehnerpotenzen mehr als bei den
1092 vorherigen Sortiernetzwerken, aber immernoch fünf Zehnerpotenzen kleiner als
1093 die Anzahl der \emph{möglichen} Schnittmuster.
1094
1095 \newpage
1096 \section{Der \textsc{SN-Evolution}-Algorithmus}
1097
1098 Der \textsc{SN-Evolution}-Algorithmus ist ein \emph{evolutionärer
1099 Algorithmus}, der die in den vorherigen Abschnitten beschriebenen Mischer
1100 (Abschnitt~\ref{sect:konstruktive_netzwerke}) und Schnittmuster
1101 (Abschnitt~\ref{sect:leitungen_entfernen}) verwendet, um „möglichst gute“
1102 Sortiernetzwerke zu erzeugen. Was ein „gutes“ Sortiernetzwerk ausmacht, wird
1103 in Abschnitt~\ref{sect:bewertung} behandelt.
1104
1105 \subsection{Bewertungsfunktion}\label{sect:bewertung}
1106
1107 Um Sortiernetzwerke überhaupt optimieren zu können, muss zunächst die
1108 {\em Güte} eines Netzwerkes definiert werden. Prinzipiell gibt es zwei Ziele,
1109 die bei Sortiernetzwerken verfolgt werden können:
1110 \begin{itemize}
1111   \item Möglichst wenige Komparatoren („billig“)
1112   \item Möglichst wenige Schichten („schnell“)
1113 \end{itemize}
1114
1115 Diese Ziele führen im Allgemeinen zu unterschiedlichen Netzwerken. Das
1116 billigste bekannte Sortiernetzwerk für 16~Eingänge besteht aus 60~Komparatoren
1117 in 10~Schichten. Das schnellste Netzwerk besteht aus 61~Komparatoren in nur
1118 9~Schichten.
1119
1120 Eine Gütefunktion, die die beiden Ziele "`billig"' und "`schnell"'
1121 berücksichtigen kann, hat die folgende allgemeine Form:
1122 \begin{equation}
1123   \operatorname{Guete}(S) = w_{\mathrm{Basis}}
1124                     + w_{\mathrm{Komparatoren}} \cdot \left|S\right|_\mathrm{Komparatoren}
1125                     + w_{\mathrm{Schichten}} \cdot \left|S\right|_\mathrm{Schichten}
1126 \end{equation}
1127 Die Parameter $w_{\mathrm{Komparatoren}}$ und $w_{\mathrm{Schichten}}$ dienen
1128 dabei der Festlegung des Optimierungsziels. Wenn einer der beiden Parameter
1129 gleich Null ist, wird nur das jeweils andere Ziel verfolgt. Sind beide
1130 Parameter gleich Null, werden alle Netzwerke mit der gleich Güte bewertet --
1131 jegliche Ergebnisse sind dann rein zufälliger Natur.\footnote{Dass dies nicht
1132 so schlecht ist wie man intuitiv vermuten könnte, zeigt der
1133 \textsc{SN-Markov}-Algorithmus in Abschnitt~\ref{sect:markov}.}
1134
1135 Da möglichst billige und schnelle Sortiernetzwerke gefunden werden sollen, ist
1136 ein kleiner Wert von $\operatorname{Guete}(S)$ besser als ein großer Wert. Das
1137 heißt, dass das Ziel von \textsc{SN-Evolution} ist, $\operatorname{Guete}(S)$
1138 zu \emph{minimieren}.
1139
1140 Mit dem Parameter $w_{\mathrm{Basis}}$ kann auf die Selektion Einfluss
1141 genommen werden. Ist er groß, wird der relative Unterschied der Güten
1142 verschiedener Netzwerke kleiner, was die {\em Exploration}, das Absuchen des
1143 gesamten Lösungsraums, begünstigt. Wählt man $w_{\mathrm{Basis}}$ hingegen
1144 klein -- in Abhängigkeit von den anderen beiden Parametern sind auch negative
1145 Werte möglich -- werden die relativen Unterschiede groß. Dadurch wird die {\em
1146 Exploitation}, das Finden (lokaler) Optima, bevorzugt.
1147
1148 Diese Parameter haben einen großen Einfluss auf die Geschwindigkeit, mit der
1149 der \textsc{SN-Evolution}-Algorithmus konvergiert und ob er tatsächlich gute
1150 Lösungen findet oder sich in \emph{lokalen} Optima verrennt. Leider gibt es
1151 kein Patentrezept für die Wahl der Parameter, so dass für verschiedene
1152 Leitungszahlen und Mischer-Typen experimentiert werden muss.
1153
1154 \subsection{Selektion}
1155
1156 Die \emph{Selektion} sorgt dafür, dass bessere Individuen eine größere
1157 Wahrscheinlichkeit haben, zur nächsten Generation beizutragen. Diese
1158 Ungleichbehandlung von Individuen verschiedener Güte ist der Grund für das
1159 Streben des Algorithmus nach besseren Lösungen.
1160
1161 Obwohl dieser Vorteil für gute Individuen intuitiv als sehr gering erscheint,
1162 ist es sehr häufig, dass die \emph{Exploitation} überhand gewinnt und der
1163 Algorithmus vorschnell in Richtung eines lokalen Optimums optimiert.
1164
1165 Die in \textsc{SN-Evolution} implementierte Selektion lässt sich mithilfe von
1166 Pseudocode wie folgt beschreiben:
1167 \begin{verbatim}
1168 Guetesumme := 0
1169 Auswahl := (leer)
1170
1171 fuer jedes Individuum in Population
1172 {
1173   reziproke Guete := 1.0 / Guete(Individuum)
1174   Wahrscheinlichkeit P := reziproke Guete / (reziproke Guete + Guetesumme)
1175   Guetesumme := Guetesumme + reziproke Guete
1176
1177   mit Wahrscheinlichkeit P
1178   {
1179     Auswahl := Individuum
1180   }
1181 }
1182 gebe Auswahl zurueck
1183 \end{verbatim}
1184
1185 \subsection{Rekombination}
1186
1187 Bei der Rekombination werden zwei Individuen --~hier Sortiernetzwerke~-- zu
1188 einer neuen Lösung kombiniert. Dazu verwenden wir einen Mischer, zum Beispiel
1189 den {\em bitonen Mischer} (Abschnitt~\ref{sect:der_bitone_mischer}) oder den
1190 {\em Odd-Even-Mischer} (Abschnitt~\ref{sect:der_odd_even_mischer}), um die
1191 beiden Netzwerke zu einem Netzwerk mit $2n$~Leitungen zusammenzufügen.
1192 Anschließend entfernen wir zufällig $n$~Leitungen wie in
1193 Abschnitt~\ref{sect:leitungen_entfernen} beschrieben.
1194
1195 Dieses Verfahren hat den großen Vorteil, dass es die Sortiereigenschaft
1196 erhält.
1197
1198 \subsection{Mutation}
1199
1200 Zu einem vollständigen evolutionären Algorithmus gehört außerdem eine Mutation
1201 --~eine zufällige Veränderung einer Lösung. Leider ist es nicht möglich ein
1202 Sortiernetzwerk zufällig zu verändern aber trotzdem die Sortiereigenschaft zu
1203 erhalten. Selbst das \emph{Hinzufügen} eines zufälligen Komparators kann diese
1204 Eigenschaft zerstören.
1205
1206 Nach einer Mutation müsste man überprüfen, ob das neue Komparatornetzwerk die
1207 Sortiereigenschaft noch besitzt. Nach heutigem Wissenstand ist diese
1208 Überprüfung nur mit exponentiellem Aufwand möglich, etwa durch das
1209 Ausprobieren aller $2^n$~Bitmuster.
1210
1211 Um das Potenzial einer Mutation abzuschätzen habe ich in den evolutionären
1212 Algorithmus eine Überprüfung eingebaut. Unmittelbar vor dem Einfügen in die
1213 Population überprüft das Programm die Notwendigkeit jedes einzelnen
1214 Komparators. Dazu wurde nacheinander jeder Komparator entfernt und überprüft,
1215 ob das verbleibende Netzwerk die Sortiereigenschaft noch besitzt.
1216
1217 \begin{itemize}
1218 \item Güte von Sortiernetzwerken (Anzahl der Komparatoren, Anzahl der
1219 Schichten, kobiniert)
1220 \item Rekombination: Merge Anhängen und Leitungen entfernen.
1221 \end{itemize}
1222
1223 Ein Beispielnetzwerk, das von dem Algorithmus gefunden wird, zeigt
1224 Abbildung~\ref{fig:evolutionary_08}.
1225
1226 \begin{figure}
1227 \begin{center}
1228 \input{images/evolutionary-08.tex}
1229 \end{center}
1230 \caption{Ein mit dem evolutionären Algorithmus erzeugtes Sortiernetzwerk mit
1231 acht Eingängen. Es besteht aus 19~Komparatoren in 6~Schichten.}
1232 \label{fig:evolutionary_08}
1233 \end{figure}
1234
1235 \begin{figure}
1236 \begin{center}
1237 \input{images/08-e2-1237993371.tex}
1238 \end{center}
1239 \caption{{\tt images/08-e2-1237993371.tex}: 19~Komparatoren in 6~Schichten}
1240 \label{fig:08-e2-1237993371}
1241 \end{figure}
1242
1243 \begin{figure}
1244 \begin{center}
1245 \input{images/09-e2-1237997073.tex}
1246 \end{center}
1247 \caption{{\tt images/09-e2-1237997073.tex}: 25~Komparatoren in 8~Schichten}
1248 \label{fig:09-e2-1237997073}
1249 \end{figure}
1250
1251 \begin{figure}
1252 \begin{center}
1253 \input{images/09-e2-1237999719.tex}
1254 \end{center}
1255 \caption{{\tt images/09-e2-1237999719.tex}: 25~Komparatoren in 7~Schichten}
1256 \label{fig:09-e2-1237999719}
1257 \end{figure}
1258
1259 \begin{figure}
1260 \begin{center}
1261 \input{images/10-e2-1239014566.tex}
1262 \end{center}
1263 \caption{{\tt images/10-e2-1239014566.tex}: 29~Komparatoren in 8~Schichten}
1264 \label{fig:10-e2-1239014566}
1265 \end{figure}
1266
1267 \subsection{Güte}
1268
1269 \begin{itemize}
1270 \item So gut kann man mindestens werden {\em ($\rightarrow$ Bitonic-Mergesort, vermute ich)}.
1271 \item Wie gut die Netzwerke werden, hängt stark vom verwendeten \em{Mischer} ab.
1272 \item Ggf. Abschnitt „Shmoo-Äquivalenz“ kürzen und hier einbauen.
1273 \end{itemize}
1274
1275 %\input{shmoo-aequivalenz.tex}
1276
1277 \newpage
1278 \section{Der \textsc{SN-Evolution-Cut}-Algorithmus}
1279 \label{sect:sn-evolution-cut}
1280
1281 Das Programm \textsc{SN-Evolution-Cut} implementiert einen evolutionären
1282 Algorithmus, der zu einem gegebenen Sortiernetzwerk und einer gewünschten
1283 Leitungszahl ein Schnittmuster sucht, dass ein Sortiernetzwerk mit einer
1284 möglichst geringen Anzahl von Komparatoren und Schichten ergibt. Zur Bewertung
1285 von Sortiernetzwerken siehe auch Abschnitt~\ref{sect:bewertung}. Mit diesem
1286 Algorithmus wurden zu einer Reihe von „interessanten“ Netzwerken möglichst
1287 gute Schnittmuster gesucht.
1288
1289 Der \textsc{SN-Evolution-Cut}-Algorithmus verwendet die \emph{Schnittmuster}
1290 als Individuen. Um zwei Individuen zu rekombinieren werden die ersten
1291 $r$~Schnitte des einen Schnittmusters verwendet und die letzten
1292 ${c-r}$~Schnitte des zweiten Schmittmusters. $r$ ist eine Zufallsvariable mit
1293 $0 \leqq r \leqq c$.
1294
1295 Die Mutation setzt entweder die Leitungs-Nummer eines Schnitts~$i$ zufällig
1296 auf einen neuen Wert $l$ mit $0 \leqq l \le n-i$ oder invertiert die
1297 Schnitt-Richtung.
1298
1299 \subsection{Versuche mit dem bitonen Mergesort-Netzwerk}
1300
1301 In \cite{MW2010} zeigen \textit{Moritz Mühlenthaler} und \textit{Rolf Wanka},
1302 wie man einen bitonen Mischer, der nach Batchers Methode konstruiert wurde,
1303 durch systematisches Entfernen von Leitungen in einen ebenfalls bitonen
1304 Mischer mit der Hälfte der Leitungen transformiert. Diese alternativen Mischer
1305 sparen im Vergleich zu den Mischern, die nach Batchers Methode konstruiert
1306 werden, Komparatoren ein.
1307
1308 Beispeilsweise geben \textit{Mühlenthaler} und \textit{Wanka} ein
1309 Sortiernetzwerk mit 16~Eingängen an, das mithilfe der alternativen Mischer
1310 konstruiert wurde. Dieses Sortiernetzwerk benötigt 68~Komparatoren, 12~weniger
1311 als das bitone Mergesort-Netzwerk nach Batchers Methode. Gegenüber Batchers
1312 Methode sparen so konstruierte Sortiernetzwerke ${\frac{1}{4}n(\log n - 1)}$
1313 Komparatoren ein.
1314
1315 \begin{figure}
1316   \begin{center}
1317     \input{images/16-ec-from-bs32.tex}
1318   \end{center}
1319   \caption{Sortiernetzwerk mit 16~Leitungen und 68~Komparatoren in
1320     10~Schichten. Das Netzwerk wurde von dem Algorithmus
1321     \textsc{SN-Evolution-Cut} aus dem \emph{bitonen Mergesort-Netzwerk}
1322     $\operatorname{BS}(32)$ durch 16~Schnitte erzeugt.}
1323   \label{fig:16-ec-from-bs32}
1324 \end{figure}
1325
1326 \begin{figure}
1327   \begin{center}
1328     \input{images/16-ec-from-bs32-normalized.tex}
1329   \end{center}
1330   \caption{Sortiernetzwerk mit 16~Leitungen und 68~Komparatoren in
1331     10~Schichten. Das Netzwerk wurde von dem Algorithmus
1332     \textsc{SN-Evolution-Cut} aus dem bitonen Mergesort-Netzwerk
1333     $\operatorname{BS}(32)$ durch 16~Schnitte erzeugt.}
1334   \label{fig:16-ec-from-bs32-normalized}
1335 \end{figure}
1336
1337 Startet man {\sc SN-Evolution-Cut} mit dem bitonen Mergesort-Netzwerk
1338 $\operatorname{BS}(32)$ und der Vorgabe 16~Leitungen zu entfernen, liefert der
1339 Algorithmus Sortiernetzwerke, die ebenfalls aus 68~Komparatoren bestehen. Ein
1340 16-Sortiernetzwerk, das auf diese Weise generiert wurde, ist in den
1341 Abbildungen~\ref{fig:16-ec-from-bs32} und~\ref{fig:16-ec-from-bs32-normalized}
1342 zu sehen. Abbildung~\ref{fig:16-ec-from-bs32} zeigt $\operatorname{BS}(32)$
1343 und das
1344 ${\operatorname{MIN}(0,5,9,11,15,17,20,22,26,29,30)}$-${\operatorname{MAX}(2,4,13,19,24)}$-Schnittmuster,
1345 das durch \textsc{SN-Evolution-Cut} gefunden wurde.
1346 Abbildung~\ref{fig:16-ec-from-bs32-normalized} zeigt das 16-Sortiernetzwerk
1347 nachdem das Schnittmuster angewandt und das Netzwerk normalisiert wurde. Eine
1348 Ähnlichkeit zu $\operatorname{BS}(32)$ oder $\operatorname{BS}(16)$ ist in
1349 diesem Netzwerk nicht mehr erkennbar -- insbesondere die ersten Schichten des
1350 Netzwerks scheinen rein zufällig zu sein.
1351
1352 \begin{figure}
1353   % 0:MAX 1:MAX 4:MIN 6:MAX 9:MAX 11:MAX 14:MIN 15:MAX 18:MAX 19:MAX 21:MAX
1354   % 23:MIN 24:MAX 25:MAX 30:MIN 31:MIN 32:MAX 34:MAX 36:MIN 37:MAX 40:MAX
1355   % 43:MAX 46:MIN 47:MAX 48:MAX 49:MAX 54:MIN 55:MAX 56:MAX 58:MIN 60:MAX
1356   % 63:MAX
1357   \begin{center}
1358     \input{images/32-ec-from-bs64.tex}
1359   \end{center}
1360   \caption{Sortiernetzwerk mit 32~Leitungen und 206~Komparatoren in
1361     15~Schichten. Das Netzwerk wurde von dem Algorithmus
1362     \textsc{SN-Evolution-Cut} aus dem bitonen Mergesort-Netzwerk
1363     $\operatorname{BS}(64)$ durch 32~Schnitte erzeugt. Das zugehörige
1364     Schnittmuster ist
1365     $\operatorname{MIN}(4, 14, 23, 30, 31, 36, 46, 54, 58)$,
1366     $\operatorname{MAX}(0, 1, 6, 9, 11, 15, 18, 19, 21, 24, 25, 32, 34, 37,
1367     40, 43, 47, 48, 49, 55, 56, 60, 63)$.}
1368   \label{fig:32-ec-from-bs64}
1369 \end{figure}
1370
1371 Das Ergebnis von \textit{Mühlenthaler} von \textit{Wanka}, die den bitonen
1372 Mischer optimiert und anschließend aus diesen Mischern ein Sortiernetzwerk
1373 konstruiert haben, kann demnach auch erreicht werden, wenn
1374 $\operatorname{BS}(32)$ auf ein 16-Sortiernetzwerk reduziert wird. Bei anderen
1375 Größen, beispielsweise wenn man $\operatorname{BS}(64)$ auf ein
1376 32-Sortiernetzwerk reduziert, kann das Ergebnis sogar noch übertroffen werden,
1377 wie in Abbildung~\ref{fig:32-ec-from-bs64} zu sehen: Ein nach Batchers Methode
1378 konstruiertes Sortiernetzwerk benötigt 240~Komparatoren, ein aus den
1379 optimierten Mischern aufgebautes Netzwerk verbessert die Kosten auf
1380 208~Komparatoren. Das in Abbildung~\ref{fig:32-ec-from-bs64} dargestellte
1381 Sortiernetzwerk benötigt lediglich 206~Komparatoren. Die Komparatoren aller
1382 dieser Netzwerke können in 15~Schichten angeordnet werden, so dass die
1383 Verzögerung dieser Sortiernetzwerke gleich ist.
1384
1385 Leider sind die Schnittmuster, die \textsc{SN-Evolution-Cut} ausgibt, sehr
1386 unregelmäßig. Bisher ist es nicht gelungen eine Konstruktionsanweisung für
1387 gute Schnittmuster anzugeben.
1388
1389 Entscheidend für das Ergebnis eines Schnittmusters scheint beim bitonen
1390 Mergesort-Netzwerk die Aufteilung der Minimum- und Maximumschnitte zu sein.
1391 Von Hundert 16-Schnittmustern für $\operatorname{BS}(32)$, die in
1392 Sortiernetzwerken mit 68~Komparatoren in 10~Schichten resultieren, hatten 73
1393 ein Verhältnis von $5/11$, 13 hatten ein Verhältnis von $4/12$ und 14 hatten
1394 ein Verhältnis von $3/13$ Minimum- beziehungsweise Maximumschnitten. Da sich
1395 die Schnittmuster aufgrund der Symmetrie des bitonen Mergesort-Netzwerks
1396 leicht invertieren lassen, werden der Fall, dass es mehr Minimumschnitte, und
1397 der Fall, dass es mehr Maximumschnitte gibt, nicht unterschieden.
1398
1399 Dass die Ergebnisse von \textsc{SN-Evolution-Cut} keine erkennbare Struktur
1400 haben, ist jedoch kein Eigenschaft des Algorithmus, sondern hängt insbesondere
1401 von der Eingabe ab. Wird \textsc{SN-Evolution-Cut} beispielsweise mit dem
1402 \emph{Odd-Even-Transpositionsort-Netzwerk} $\operatorname{OET}(n)$ und
1403 $m$~Schnitten gestartet, so ist das beste Ergebnis immer das
1404 $\operatorname{OET}(n-m)$-Netzwerk. 
1405
1406 \begin{figure}
1407   \begin{center}
1408     \input{images/16-ec-from-ps32.tex}
1409   \end{center}
1410   \caption{Sortiernetzwerk mit 16~Leitungen und 63~Komparatoren in
1411     10~Schichten. Das Netzwerk wurde von dem Algorithmus
1412     \textsc{SN-Evolution-Cut} aus dem \emph{Pairwise-Sorting-Netzwerk}
1413     $\operatorname{PS}(32)$ durch 16~Schnitte erzeugt.}
1414   \label{fig:16-ec-from-ps32}
1415 \end{figure}
1416
1417 \subsection{Versuche mit dem Pairwise-Sorting-Netzwerk}
1418
1419 Anders verhält sich das \emph{Pairwise-Sorting-Netzwerk}
1420 $\operatorname{PS}(n)$, das \textit{Ian Parberry} in seiner Arbeit „The
1421 Pairwise Sorting Network“ \cite{P1992} definiert. Startet man
1422 \textsc{SN-Evolution-Cut} mit $\operatorname{PS}(32)$ und der Vorgabe,
1423 16~Leitungen zu entfernen, erhält man ein Sortiernetzwerk, dass die gleiche
1424 Anzahl an Komparatoren und Schichten hat wie $\operatorname{PS}(16)$ und
1425 $\operatorname{OES}(16)$. Eines dieser Sortiernetzwerke ist in
1426 Abbildung~\ref{fig:16-ec-from-ps32} dargestellt.
1427
1428 Obwohl das \emph{Pairwise-Sorting-Netzwerk} den \emph{Odd-Even-Mischer} nicht
1429 einsetzt und auch nicht auf einem Mischer basiert, ist der
1430 $\operatorname{OEM}(8,8)$ im Sortiernetzwerk in
1431 Abbildung~\ref{fig:16-ec-from-ps32} eindeutig erkennbar (Schichten~7--10). In
1432 den Schichten~1--6 erkennt man zwei unabhängige Sortiernetzerke, die
1433 strukturell identisch zu $\operatorname{PS}(8)$ sind -- lediglich die
1434 Schichten~1 und~2 sowie 4~und~5 sind vertauscht.
1435
1436 \begin{displaymath}
1437 \textit{Eingang}_i = \left\{ \begin{array}{rl}
1438   -\infty & \quad \textrm{falls } i \operatorname{mod} 8 \in \{0, 6\} \\
1439    \infty & \quad \textrm{falls } i \operatorname{mod} 8 \in \{2, 4\} \\
1440         ? & \quad \mathrm{sonst}
1441   \end{array} \right.
1442 \end{displaymath}
1443
1444 \begin{figure}
1445   \begin{center}
1446     \input{images/32-pairwise-cut-16-pairwise.tex}
1447   \end{center}
1448   \caption{PS(32) mit 16 Schnitten zu PS(16).}
1449   \label{fig:ps16-from-ps32}
1450 \end{figure}
1451
1452 \begin{figure}
1453   \begin{center}
1454     \input{images/16-pairwise.tex}
1455   \end{center}
1456   \caption{Das $\operatorname{PS}(16)$-Sortiernetzwerk mit 8~Schnitten
1457   ($\operatorname{MIN}(0,2,4,6), \operatorname{MAX}(9,11,13,15)$). Das
1458   resultierende 8-Sortiernetzwerk ist $\operatorname{OES}(8)$.}
1459   \label{fig:16-pairwise}
1460 \end{figure}
1461
1462 Wendet man \textsc{SN-Evolution-Cut} auf $\operatorname{PS}(16)$ an, so kann
1463 man $\operatorname{OES}(8)$ erhalten.
1464
1465 \subsection{Versuche mit dem Odd-Even-Mergesort-Netzwerk}
1466
1467 \todo{Schreibe noch etwas zum Odd-Even-Mergesort-Netzwerk.}
1468
1469 \begin{itemize}
1470   \item Beispiel: Moritz und Rolfs Optimierung für Bitonic-Sort.
1471   \item Wie gut kann man durch wegschneiden werden?
1472   \item Wieviele Schnitte ergeben das selbe Netzwerk? Oder andersrum: Wieviele
1473   unterschiedliche Netzwerke kann ich erhalten? Wieviele Nachfolger hat ein
1474   Netzwerk / Knoten in der Markov-Kette?
1475   \item Abschnitt „Optimierung der Schnitte“ hier einbauen.
1476 \end{itemize}
1477
1478 \newpage
1479 \section{Der \textsc{SN-Markov}-Algorithmus}
1480 \label{sect:markov}
1481
1482 Der evolutionäre \textsc{SN-Evolution}-Algorithmus aus dem vorherigen
1483 Abschnitt verwendete immer zwei zufällige Sortiernetzwerke („Individuen“) aus
1484 einer Population. Da die beiden „Eltern“ zufällig und unabhängig voneinander
1485 ausgewählt werden, kann es vorkommen, dass das selbe Sortiernetzwerk zweimal
1486 verwendet und mit sich selbst kombiniert wird.
1487
1488 Macht man diesen Spezialfall zum Regelfall, indem man \emph{immer} das
1489 aktuelle Netzwerk mit sich selbst kombiniert und anschließend die Hälfte aller
1490 Leitungen eliminiert, lassen sich einige interessante Beobachtungen anstellen.
1491 Netzwerke, die aus einem Netzwerk $S_0$ durch die beschriebene Kombination von
1492 $S_0$ mit sich selbst und anschließendem Eliminieren der Hälfte der Leitungen
1493 hervorgehen können, heißen \emph{Nachfolger} von $S_0$.
1494
1495 Beim beschriebenen Vorgehen kann man die Sortiernetzwerke als Knoten in einem
1496 (gerichteten) Graphen betrachten. Zwei Knoten $V_0$ und $V_1$, die zwei
1497 Sortiernetzwerke $S_0$ und $S_1$ repräsentieren, sind genau dann mit einer
1498 Kante ${E_{0,1} = (V_0, V_1)}$ verbunden, wenn $S_1$ ein \emph{Nachfolger} von
1499 $S_0$ ist, das heißt dass man $S_1$ durch die Rekombination von $S_0$ mit sich
1500 selbst erzeugen kann.
1501
1502 Wie in Abschnitt~\ref{sect:anzahl_schnittmuster} beschrieben ist die Anzahl
1503 (unterschiedlicher) Schnittmuster und damit die Anzahl der Nachfolger sehr
1504 groß. Wenn $S_0$ ein Sortiernetzwerk mit $n$~Leitungen ist, so hat $S_0$ bis
1505 zu
1506 \begin{displaymath}
1507   2^n \cdot \left( \begin{array}{c} 2n \\ n \end{array} \right)
1508 \end{displaymath}
1509 Nachfolger.
1510
1511 Der Algorithmus {\sc SN-Markov} legt auf diesem Nachfolger-Graph einen
1512 zufälligen Weg (englisch: \textit{random walk}) zurück. Er startet auf einem
1513 gegebenen Sortiernetzwerk. Um von einem Sortiernetzwerk zum Nächsten zu
1514 gelangen, rekombiniert der Algorithmus das aktuelle Sortiernetzwerk mit sich
1515 selbst und erhält so einen zufälligen Nachfolger.
1516
1517 \begin{itemize}
1518   \item $n \leftarrow \mathrm{Input}$
1519   \item \texttt{while} \textit{true}
1520   \begin{itemize}
1521     \item $n \leftarrow \operatorname{recombine} (n, n)$
1522   \end{itemize}
1523 \end{itemize}
1524
1525 \begin{itemize}
1526   \item Beste erreichte Netzwerke (gleich zu \emph{OE-Mergesort}).
1527   \item Anzahl der erreichbaren Sortiernetzwerke.
1528   \item Anzahl der Komparatoren und Anzahl der Schichten der durchlaufenen
1529     Netzwerke. (Abbildung~\ref{fig:markov-comparators-16})
1530 \end{itemize}
1531
1532 \begin{figure}
1533   \begin{center}
1534   \includegraphics[viewport=0 0 360 216,width=15cm]{images/markov-comparators-12-pct.pdf}
1535   \end{center}
1536   \caption{Anzahl der Komparatoren von Sortiernetzwerken (mit 12~Leitungen),
1537   die von {\sc SN-Markov} durchlaufen wurden. Grün eingezeichnet ist die
1538   \emph{Gamma-Verteilung} $f(x - 40)$ mit $k = 8,267$ und $\theta = 0,962$.}
1539   \label{fig:markov-comparators-12}
1540 \end{figure}
1541
1542 \begin{figure}
1543   \begin{center}
1544   \includegraphics[viewport=0 0 360 216,width=15cm]{images/markov-comparators-14-pct.pdf}
1545   \end{center}
1546   \caption{Anzahl der Komparatoren von Sortiernetzwerken (mit 14~Leitungen),
1547   die von {\sc SN-Markov} durchlaufen wurden. Grün eingezeichnet ist die
1548   \emph{Gamma-Verteilung} $f(x - 52)$ mit $k = 9,522$ und $\theta = 0,867$.}
1549   \label{fig:markov-comparators-14}
1550 \end{figure}
1551
1552 \begin{figure}
1553   \begin{center}
1554   \includegraphics[viewport=0 0 360 216,width=15cm]{images/markov-comparators-16-pct.pdf}
1555   \end{center}
1556   \caption{Anzahl der Komparatoren von Sortiernetzwerken (mit 16~Leitungen),
1557   die von {\sc SN-Markov} durchlaufen wurden. Grün eingezeichnet ist die
1558   \emph{Gamma-Verteilung} $f(x - 62)$ mit $k = 17,939$ und $\theta = 1,091$.}
1559   \label{fig:markov-comparators-16}
1560 \end{figure}
1561
1562 \newpage
1563 \section{Empirische Beobachtungen}
1564
1565 \begin{itemize}
1566 \item So schnell konvergiert der Algorithmus.
1567 \item $\ldots$
1568 \end{itemize}
1569
1570 \newpage
1571 \section{Ausblick}
1572
1573 Das würde mir noch einfallen$\ldots$
1574
1575 \newpage
1576 \section{Implementierung}
1577
1578 So habe ich die ganzen Versuche durchgeführt.
1579
1580 \newpage
1581 \bibliography{references}
1582 \bibliographystyle{plain}
1583
1584 %\listoffigures
1585
1586 \end{document}
1587
1588 % vim: set shiftwidth=2 softtabstop=2 tabstop=8 fdm=marker tw=78 :