c4ac16576f2e133b358bd7100d87b48476fdc336
[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 \newcommand{\oes}[1]{\ensuremath{\operatorname{OES}(#1)}}
40 \newcommand{\bs}[1]{\ensuremath{\operatorname{BS}(#1)}}
41 \newcommand{\ps}[1]{\ensuremath{\operatorname{PS}(#1)}}
42 \newcommand{\oem}[1]{\ensuremath{\operatorname{OEM}(#1)}}
43 \newcommand{\bm}[1]{\ensuremath{\operatorname{BM}(#1)}}
44 \newcommand{\oet}[1]{\ensuremath{\operatorname{OET}(#1)}}
45
46 \newtheorem{definition}{Definition}
47 \newtheorem{satz}{Satz}
48
49 % Zeige Nummern nur bei referenzierten Gleichungen an.
50 \mathtoolsset{showonlyrefs=true}
51
52 \begin{document}
53
54 \tikzstyle{vertex}   = [circle,draw,thick,fill=black,minimum size=5,inner sep=0pt]
55 \tikzstyle{comp}     = [draw,thick,-]
56 \tikzstyle{compup}   = [draw,thick,->]
57 \tikzstyle{compdown} = [draw,thick,<-]
58 \tikzstyle{edge}     = [draw,thick,-]
59 \tikzstyle{diredge}  = [draw,thick,->]
60 \tikzstyle{prob}     = [font=\tiny]
61
62 \tikzstyle{edge minimum} = [edge,color=blue!20]
63 \tikzstyle{edge maximum} = [edge,color=red!20]
64 \tikzstyle{vertex active minimum} = [vertex,color=blue!50, fill=blue!50]
65 \tikzstyle{vertex active maximum} = [vertex,color=red!50, fill=red!50]
66 \tikzstyle{vertex active minimum maximum} = [vertex,color=violet!50, fill=violet!50]
67 \tikzstyle{vertex inactive minimum} = [vertex,color=blue!20, fill=blue!20]
68 \tikzstyle{vertex inactive maximum} = [vertex,color=red!20, fill=red!20]
69 \tikzstyle{vertex inactive minimum maximum} = [vertex,color=black!20, fill=black!20]
70 \tikzstyle{comp active minimum} = [comp]
71 \tikzstyle{comp active maximum} = [comp]
72 \tikzstyle{comp active minimum maximum} = [comp,color=black!20]
73 \tikzstyle{comp inactive minimum} = [comp,color=blue!20]
74 \tikzstyle{comp inactive maximum} = [comp,color=red!20]
75 \tikzstyle{comp inactive minimum maximum} = [comp,color=black!20]
76
77 \tikzstyle{red box}   = [draw,-,color=red, top color=red!2,bottom color=red!10]
78 \tikzstyle{blue box}  = [draw,-,color=blue,top color=blue!2,bottom color=blue!10]
79 \tikzstyle{green box} = [draw,-,color=teal,top color=teal!2,bottom color=teal!10]
80 \tikzstyle{gray box}  = [draw,-,color=black, top color=black!2,bottom color=black!10]
81
82 \maketitle
83 \begin{abstract}
84 Sortiernetzwerke werden eingeführt und einige bekannte Konstruktionen werden
85 vorgestellt (Odd-Even-Transposition, Bitonic-Merge, Odd-Even-Merge, Pairwise).
86 Transformationsmöglichkeiten für Sortiernetzwerke werden besprochen.
87 Evolutionäre Algorithmen werden beschrieben und ein evolutionärer
88 Algorithmus für die Optimierung von Sortiernetzwerken wird angegeben.
89 Die mindestens von diesem Algorithmus erreichte Güte wird angegeben und die
90 Transformation zu einer Markov-Kette wird gezeigt. {\em Natürlich: So fern ich
91 das hinbekomme bzw. Recht behalte.}
92 \end{abstract}
93 \newpage
94
95 \tableofcontents
96
97 \newpage
98 \section{Motivation und Einleitung}
99
100 \subsection{Motivation}\label{sect:motivation}
101
102 \todo{Schreibe noch etwas zu …}
103 \begin{itemize}
104 \item Sortiernetzwerke sind toll, weil $\ldots$
105 \item Sortiernetzwerke sind einfach erklärt, aber trotzdem kompliziert.
106 \item Bisher noch kein evolutionärer Algorithmus zur automatischen
107   Optimierung von Sortiernetzwerken bekannt. \textit{(Glaube ich zumindest.)}
108 \end{itemize}
109
110 \subsection{Einleitung}\label{sect:einleitung}
111
112 \subsubsection{Sortiernetzwerke}\label{sect:einleitung_sortiernetzwerke}
113
114 \emph{Komparatoren} sind die Bausteine, die \emph{Komparatornetzwerken}
115 zugrunde liegen. Sie haben zwei Eingänge über die sie zwei Zahlen erhalten
116 können und zwei Ausgänge, auf denen die Zahlen wieder ausgegeben werden. Dabei
117 sind die Ausgänge im Gegensatz zu den Eingängen unterscheidbar, da die größere
118 der beiden Zahlen wird immer auf dem einen, die kleinere der beiden Zahlen
119 immer auf dem anderen Ausgang ausgegeben ausgegeben wird.
120
121 Kombiniert man mehrere \emph{Komparatoren} miteinander, das heißt, dass die
122 Ausgänge eines Komparators mit Eingängen weiterer Komparatoren verbunden sind,
123 erhält man ein {\em Komparatornetzwerk}.
124
125 \begin{figure}
126 \begin{center}
127 \input{images/einfaches_komparatornetzwerk.tex}
128 \end{center}
129 \caption{Einfaches Komparatornetzwerk mit vier Ein- bzw. Ausgängen, bestehend
130 aus 5~Komparatoren.}
131 \label{fig:einfaches_komparatornetzwerk}
132 \end{figure}
133
134 Abbildung~\ref{fig:einfaches_komparatornetzwerk} zeigt ein einfaches
135 \emph{Komparatornetzwerk} aus fünf Komparatoren. Insgesamt gibt es vier
136 verschiedene Eingänge und vier Ausgänge. Die Ein- und Ausgänge werden durch
137 eine horizontale Linie dargestellt und als \emph{Leitung} bezeichnet. Die
138 \emph{Komparatoren} sind durch vertikale Pfeile dargestellt und verbinden je
139 zwei verschiedene \emph{Leitungen} miteinander. Die Verbindungsstellen von
140 \emph{Leitungen} und \emph{Komparatoren} sind zur besseren Übersichlichkeit
141 durch schwarze Punkte symbolisiert.
142
143 Auf der linken Seite befinden sich die Eingänge. Hier wird eine Zahlenfolge in
144 das Netzwerk hineingegeben. Jeder Komparator vergleicht die Zahlen „auf“ den
145 beiden Leitungen, die er verbindet. Nach einem Komparator befindet sich die
146 kleinere Zahl immer auf der Leitung, auf die der Pfeil zeigt, die größere Zahl
147 befindet sich auf der Leitung, auf der der Pfeil seinen Ursprung hat.
148
149 Komparatoren, die unterschiedliche Leitungen miteinander vergleichen, können
150 gleichzeitig angewandt werden. Das Beispiel in
151 Abbildung~\ref{fig:einfaches_komparatornetzwerk} verwendet diesen Umstand und
152 vergleicht die zwei oberen und die zwei unteren Leitungen gleichzeitig. Eine
153 Gruppe von Komparatoren, die gleichzeitig angewendet werden können, nennt man
154 eine \emph{Schicht} des Komparatornetwerks. Die \emph{Verzögerung} eines
155 Komparatornetzwerks ist gleichbedeutend mit der Anzahl der Schichten, in die
156 sich die Komparatoren mindestens gruppieren lassen, da sie die Anzahl der
157 benötigten parallelen Schritte darstellt.
158
159 \emph{Komparatornetzwerke}, die für \emph{jede} Eingabefolge eine Ausgabe
160 erzeugen, die der Sortierung der Eingabe entspricht, heißen
161 \emph{Sortiernetzwerke}. Das in
162 Abbildung~\ref{fig:einfaches_komparatornetzwerk} gezeigte Komparatornetzwerk
163 ist \emph{kein} Sotiernetzwerk: Die Eingabefolge ${(1, 2, 3, 4)}$ führt zur
164 Ausgabe ${(2, 1, 3, 4)}$ -- die bestehenden Sortierung wird also sogar
165 zerstört.
166
167 \begin{figure}
168   \begin{center}
169     \input{images/09-e2-c24-allbut1.tex}
170   \end{center}
171   \caption{Ein \emph{Komparatornetzwerk} mit neun Eingängen und
172   24~Komparatoren, die in 8~Schichten angeordnet sind. Das Netzwerk sortiert
173   alle Eingaben, bei denen das Minimum nicht auf dem mittleren Eingang liegt.}
174   \label{fig:09-e2-c24-allbut1}
175 \end{figure}
176 Zu beweisen, dass ein gegebenes Komparatornetzwerk die Sortiereigenschaft {\em
177 nicht} hat, ist mit einem gegebenen Gegenbeispiel einfach möglich. Das
178 Komparatornetzwerk wird auf das Gegenbeispiel angewendet und anschließend wird
179 überprüft, ob die Ausgabe sortiert ist. Ist sie es nicht heißt das, dass es
180 mindestens eine Eingabefolge gibt, die nicht sortiert wird. Entsprechend der
181 Definition handelt es sich bei dem \emph{Komparatornetzwerk} folglich
182 \emph{nicht} um ein \emph{Sortiernetzwerk}. Ein solches Gegenbeispiel für ein
183 gegebenes Komparatornetzwerk zu finden ist nach heutigem Kenntnisstand jedoch
184 nicht \emph{effizient} möglich.
185
186 Beispielsweise sortiert das im Rahmen dieser Arbeit entdeckte
187 Komparatornetzwerk in Abbildung~\ref{fig:09-e2-c24-allbut1} viele der 362.880
188 möglichen Eingabepermutationen. Mit dem Gegenbeispiel $(3, 5, 2, 1, 0, 7, 4,
189 8, 6)$ lässt sich jedoch leicht beweisen, dass das Komparatornetzwerk die
190 Sortiereigenschaft \emph{nicht} besitzt, da es in diesem Fall die Folge $(1,
191 0, 2, 3, 4, 5, 6, 7, 8)$ ausgibt.
192
193 Insgesamt gibt es $n!$~Permutationen von $n$~Elementen. Wenn ein
194 Komparatornetzwerk die Sortiereigenschaft besitzt, bildet es alle diese
195 Permutationen auf die sortierte Reihenfolge ab. Allerdings wächst $n!$
196 über-exponentiell schnell, so dass ein Ausprobieren aller möglichen
197 Permutationen schon bei 16~Leitungen praktisch nicht mehr zu bewerkstelligen
198 ist.\footnote{1.307.674.368.000 Permutationen}
199
200 \label{sect:0-1-prinzip}
201 Glücklicherweise reicht es aus, alle möglichen 0-1-Folgen zu überprüfen, wie
202 \textit{Donald~E. Knuth} in \cite{KNUTH} zeigt. Die Beweisidee ist folgende:
203 Angenommen ein Komparatornetzwerk sortiert alle 0-1-Folgen und es gibt eine
204 Permutation $E = (e_0, \dots, e_{n-1})$ beliebiger Zahlen, die nicht sortiert
205 wird. Die Ausgabefolge sei $A = (a_0, \dots, a_{n-1})$. Sei $i$ eine Position
206 in der Ausgabe, die die Sortierbedingung verletzt:
207 \begin{displaymath}
208   a_0 \leqq a_1 \leqq \dots \leqq a_{i-1} > a_i \dots
209 \end{displaymath}
210 Die Eingabe kann mittels
211 \begin{displaymath}
212   \hat{e}_j = \left\{
213     \begin{array}{cl}
214       0 & e_j \leqq a_i \\
215       1 & e_j > a_i
216     \end{array} \right.
217 \end{displaymath}
218 auf eine 0-1-Folge abgebildet werden, die entsprechen der Annahme vom
219 Komparatornetzwerk sortiert wird. Allerdings verändert diese Abbildung das
220 Verhalten jedes einzelnen Komparators nicht: Wenn bei der Permutation eine
221 Zahl größer als $a_i$ und eine Zahl kleiner oder gleich $a_i$ verglichen
222 wurden, liegen jetzt entsprechend eine Null und eine Eins an, die genauso
223 vertauscht werden oder nicht, wie das bei der Permutation der Fall war. Liegen
224 zwei Nullen oder zwei Einsen an, entsprechen sie zwei Zahlen kleiner als $a_i$
225 oder zwei Zahlen größer oder gleich $a_i$. Da im Fall der 0-1-Folge zwei
226 gleiche Zahlen am Komparator anliegen, dürfen wir davon ausgehen, dass sich
227 der Komparator so verhält, wie er sich bei der Permutation verhalten hat --
228 ohne das Ergebnis zu beeinflussen. Entsprechend kommen an den Ausgängen $i-1$
229 und $i$ eine Null und eine Eins in der falschen Reihenfolge an. Das steht im
230 Widerspruch zu der Annahme, dass alle 0-1-Folgen sortiert werden.
231
232 Im Gegensatz zum Überprüfen aller möglichen Permutationen, was der
233 Komplexitätsklasse
234 $\mathcal{O}\left(\sqrt{n}\left(\frac{n}{e}\right)^n\right)$ zuzuordnen ist,
235 ist das Überprüfen aller 0-1-Folgen „nur“ mit dem Aufwand $\mathcal{O}(2^n)$
236 verbunden. Entsprechend ist dieses Verfahren nicht \emph{effizient} -- ein
237 schnelleres Verfahren ist bisher allerdings nicht bekannt. Um zu überprüfen,
238 ob ein Komparatornetzwerk mit 16~Leitungen die Sortiereigenschaft besitzt,
239 sind mit dieser Methode nur 65.536 Tests notwendig -- eine Zahl, die für
240 aktuelle Prozessoren keine Herausforderung darstellt. Für die Überprüfung
241 eines Komparatornetzwerks mit 32~Leitungen sind jedoch bereits etwa
242 4,3~Millarden Tests notwendig, die einen Rechner durchaus mehrere Minuten
243 beschäftigen.
244
245 \subsubsection{Evolutionäre Algorithmen}
246
247 Viele {\em kombinatorische Optimierungsprobleme} sind schwer zu lösen -- die
248 entsprechenden Entscheidungsprobleme liegen oft in der Komplexitätsklasse
249 \textit{NP}, das heißt das keine Verfahren bekannt sind, die das Problem
250 effizient exakt lösbar. Sollte sich herausstellen, dass diese Probleme nicht
251 in der Komplexitätsklasse~\textit{P} liegen, wäre eine Konsequenz, dass es
252 effiziente exakte Algorithmen für diese Probleme nicht geben kann. Falls sich
253 hingegen herausstellt, dass diese Probleme in der
254 Komplexitätsklasse~\textit{P} liegen, wird es mit großer Wahrscheinlichkeit
255 noch einige Zeit dauern, bis auch Algorithmen mit praktikablen Zeitkonstanten
256 gefunden werden.
257
258 Aus diesem Grund besteht die Notwendigkeit einen Kompromiss einzugehen: Statt
259 die beziehungsweise eine der {\em optimalen} Lösungen als einzige Ausgabe des
260 Algorithmus zuzulassen, wird eine "`möglichst gute"' Lösung ausgegeben. Viele
261 dieser Optimierungsalgorithmen orientieren sich an Vorgängen in der Natur,
262 beispielsweise imitieren die "`Ameisenalgorithmen"' das Verhalten von Ameisen
263 auf der Futtersuche um kurze Rundreisen auf Graphen zu berechnen.
264
265 Bei {\em Evolutionären Algorithmen} stand die Evolution pate. Die Grundidee
266 ist, bekannte Lösungen zu neuen -- unter Umständen besseren -- Lösungen zu
267 kombinieren. Dabei bedient man sich der in der Evolutionstheorie etablierten
268 Nomenklatur, beispielsweise werden konkrete Lösungen für ein Problem als {\em
269 Individuen} bezeichnet.
270
271 Die Vorgehensweise lässt sich abstrakt wie folgt beschreiben. Aus einer
272 bestehenden Lösungsmenge, der {\em Population}, werden zufällig Lösungen
273 ausgesucht {\em (Selektion)} und zu einer neuen Lösung kombiniert ({\em
274 Rekombination}). Unter Umständen wird die neue Lösung noch zufällig
275 verändert {\em (Mutation)}, bevor sie in die bestehende Lösungsmenge
276 eingefügt wird. Die verwendeten Wahrscheinlichkeiten, beispielsweise bei der
277 {\em Selektion}, sind dabei nicht zwangsläufig gleichverteilt -- üblicherweise
278 werden bessere Lösungen bevorzugt. Zur Bewertung dient die sogenannte {\em
279 Gütefunktion}.
280
281 Nicht alle Probleme eignen sich für diese Strategie: Zum einen muss es möglich
282 sein, eine initiale Population zur Verfügung zu stellen, da diese als Basis
283 aller weiteren Operationen dient. Das ist häufig keine große Einschränkung, da
284 es oft einfach ist {\em irgendeine} Lösung anzugeben. Die angegebenen
285 Algorithmen verwenden als einfache, initiale Lösung häufig das
286 \emph{Odd-Even-Transpositionsort}-Netzwerk, das in
287 Abschnitt~\ref{sect:odd_even_transpositionsort} beschrieben wird. Zum anderen
288 muss eine Methode für die Rekombination existieren. Das ist insbesondere dann
289 problematisch, wenn {\em Nebenbedingungen} eingehalten werden müssen.
290
291 Beim Aussuchen von zufälligen Lösungen aus der Population, der
292 \emph{Selektion}, werden gute Lösungen bevorzugt. Wie sehr diese Lösungen
293 bevorzugt werden, hat einen starken Einfluss auf das Verhalten des
294 Algorithmus. Werden gute Lösungen stark bevorzugt, konvergiert der Algorithmus
295 schnell gegen ein (lokales) Optimum. Dieses \textit{Exploitation} (Englisch
296 für „Ausnutzung“) genannte Verhalten sorgt dafür, dass sich der Algorithmus
297 schnell auf eine Lösung festlegt und andere, möglicherweise bessere lokale
298 Optima nicht mehr findet. Werden gute Lösungen hingegen nur wenig bevorzugt,
299 erforscht der Algorithmus den Lösungsraum in viele Richtungen. Dieses
300 \textit{Exploration} (Englisch für „Erforschung“) genannte Verhalten sorgt
301 zwar dafür, dass der Algorithmus langsamer auf ein Optimum zusteuert, dafür
302 findet er aber in der Regel bessere Lösungen.
303
304 Die Parameter evolutionärer Algorithmen so einzustellen, dass sich ein guter
305 Mittelweg zwischen den beiden Extremen einstellt, ist eine Aufgabe, die sich
306 nur experimentell lösen lässt. Die genauen Parameter hängen nicht nur vom
307 eigentlichen Algorithmus, sondern auch vom konkreten Problem ab, so dass sich
308 beispielsweise bei der Optimierung von Sortiernetzwerken die Parameter
309 zwischen verschiedenen Leitungszahlen stark unterscheiden.
310
311 Die \textit{Exploration} kann von einem weiteren Mechanismus unterstützt
312 werden, der ebenfalls der Evolutionslehre entliehen ist, der \emph{Mutation}.
313 Dabei werden Lösungen zufällig verändert, so dass auch andere Lösungen „in der
314 Nähe“ von direkten Nachfolgern erreicht werden können. Das hilft insbesondere
315 bei der intensiven Suche in der Nähe eines lokalen Optimums aber auch beim
316 „Ausbrechen“ und finden noch besserer Lösungen.
317
318 Bei \emph{Sortiernetzwerken} ist eine \emph{Mutation} leider immer damit
319 verbunden, dass anschließend die Sortiereigenschaft des resultierenden
320 \emph{Komparatornetzwerks} wieder überprüft werden muss, da selbst das
321 Hinzufügen eines zufälligen Komparators diese Eigenschaft zerstören kann. Beim
322 Suchen möglichst effizienter Netzwerke ist natürlich das zufällige Entfernen
323 von Komparatoren interessanter, was die Sortiereigenschaft sehr oft aufhebt.
324
325 Die im Folgenden beschriebenen Algorithmen mutieren (verändern) daher nicht
326 die \emph{Sortiernetzwerke} selbst, sondern verzichten auf Mutation oder
327 mutieren lediglich Transformationen von Sortiernetzwerken, die die
328 Sortiereigenschaft erhält. Transformationen von Sortiernetzwerken werden in
329 Abschnitt~\ref{sect:tranformation} beschrieben, ein Algorithmus, der Mutation
330 einsetzt, wird in Abschnitt~\ref{sect:sn-evolution-cut} vorgestellt.
331
332
333 \begin{figure}
334   \begin{center}
335     \input{images/16-hillis.tex}
336   \end{center}
337   \caption{Das 16-Sortiernetzwerk, das \textit{Hillis} in~\cite{H1992} angibt.
338   Es besteht aus 61~Komparatoren in 11~Schichten.}
339   \label{fig:16-hillis}
340 \end{figure}
341 Evolutionäre Algorithmen wurden bereits mehrfach eingesetzt, um
342 Sortiernetzwerke zu untersuchen. \textit{W.~Daniel Hillis} verwendete
343 \emph{Co-Evolution} um neben Komparatornetzwerken auch „schwierige Eingaben“
344 zu optimieren~\cite{H1992}. Diese \emph{Parasiten} genannten Eingaben wurden
345 daran gemessen, bei wievielen Komparatornetzwerken sie beweisen konnten, dass
346 sie keine Sortiernetzwerke sind. So mussten bei neuen Individuen~/
347 Komparatornetzwerken nicht alle 0-1-Folgen, sondern nur erfolgreiche
348 Parasiten~/ schwierige Eingaben überprüft werden. Auf diese Art und Weise
349 gelang es \textit{Hillis} ein 16-Sortiernetzwerk mit 61~Komparatoren
350 anzugeben, das in Abbildung~\ref{fig:16-hillis} zu sehen ist.
351
352 \begin{figure}
353   \centering
354   \subfigure{\input{images/13-juille-0.tex}}
355   \subfigure{\input{images/13-juille-1.tex}}
356   \caption{13-Sortiernetzwerke, die von \textit{Hugues Juillé} mithilfe des
357   END-Algorithmus gefunden wurden. Sie bestehen jeweils aus 45~Komparatoren in
358   10~Schichten.}
359   \label{fig:13-juille}
360 \end{figure}
361 \textit{Hugues Juillé} entwickelte ein Verfahren, das er \emph{Evolving
362 Non-Determinism} (END) nannte. Dabei handelt es sich nicht um einen
363 \emph{Evolutionären Algorithmus}, wie sie hier vorgestellt wurden, sondern um
364 eine verteilte, probabilistische Breitensuche, die an die \emph{Strahlsuche}
365 (englisch: \textit{beam search}), ein Verfahren der Künstlichen Intelligenz,
366 angelehnt ist. Die aufwendigste Operation bei diesem Ansatz ist die
367 Bewertungsfunktion, die abschätzt, wieviele Komparatoren zu einem
368 Komparatornetzwerk hinzugefügt werden müssen, um ein Sortiernetzwerk zu
369 erhalten. Mit diesem Ansatz gelang es \textit{Juillé} zwei 13-Sortiernetzwerke
370 anzugeben, die mit 45~Komparatoren effizienter sind als alle bis dahin
371 Bekannten (Abbildung~\ref{fig:13-juille}).
372
373 \newpage
374 \section{Bekannte konstruktive Sortiernetzwerke}
375 \label{sect:konstruktive_netzwerke}
376
377 Übersicht über bekannte konstruktive Sortiernetzwerke.
378
379 \todo{Einleitungssatz}
380
381 \subsection{Das Odd-Even-Transpositionsort-Netzwerk}
382 \label{sect:odd_even_transpositionsort}
383
384 Das Sortiernetzwerk {\em Odd-Even-Transpositionsort} (OET) ist eines der
385 einfachsten Sortiernetzwerke. Es besteht aus $n$~{\em Schichten}, die jede
386 "`Leitung"' abwechselnd mit den benachbarten Leitungen verbindet.
387 Abbildung~\ref{fig:odd-even-transposition-08} zeigt das OET-Netzwerk für
388 ${n = 8}$ Leitungen.
389
390 \begin{figure}
391   \begin{center}
392     \input{images/oe-transposition-8.tex}
393   \end{center}
394   \caption{Das \emph{Odd-Even-Transpositionsort}-Netzwerk mit acht Eingängen.}
395   \label{fig:odd-even-transposition-08}
396 \end{figure}
397
398 Dass das Odd-Even-Transporitionsort-Netzwerk tatsächlich jede beliegibe
399 Eingabe sortiert ist nicht offensichtlich. Leicht zu sehen ist jedoch, dass
400 sowohl das Minimum als auch das Maximum durch das im Netzwerk enthaltene
401 Treppenmuster auf die unterste beziehungsweise oberste Leitung gelangt. Beim
402 Odd-Even-Transporitionsort-Netzwerk mit drei Eingängen,
403 $\operatorname{OET}(3)$, ist die Ausgabe folglich sortiert.
404
405 Die Sortiereigenschaft größerer OET-Netzwerke lässt sich rekursiv beweisen,
406 indem man $\operatorname{OET}(n)$ auf $\operatorname{OET}(n-1)$ durch
407 Herausschneiden einer Leitung reduziert. In
408 Abschnitt~\ref{sect:leitungen_entfernen} wird das Vorgehen im Detail
409 beschrieben, Abbildung~\ref{fig:oe-transposition-cut} zeigt das
410 Herausschneiden einer Leitung aus $\operatorname{OET}(8)$.
411
412 Das Odd-Even-Transporitionsort-Netzwerk ist weder in Bezug auf die Anzahl der
413 Komparatoren noch in Bezug auf die Anzahl der Schichten, in denen sich die
414 Komparatoren anordnen lassen, effizient. Es benötigt
415 ${\frac12 n (n-1)} = \mathcal{O}(n^2)$~Komparatoren, die in $n$~Schichten
416 angeordnet sind. Andere Sortiernetzwerke benötigen deutlich weniger
417 Komparatoren, beispielsweise $\mathcal{O}(n (\log n)^2)$, die in weniger
418 Schichten, zum Beispiel $\mathcal{O}(\log n)$, angeordnet sind.
419
420 Das Interessante am OET-Netzwerk ist seine einfache Konstruktion. Einige der
421 folgenden Algorithmen benötigen ein möglichst einfaches Sortiernetzwerk als
422 Starteingabe, auf dessen Basis sie versuchen optimierte Sortiernetzwerke zu
423 finden. Häufig dient $\operatorname{OET}(n)$ als Eingabe für diese
424 Algorithmen.
425
426 \subsection{Das bitone Mergesort-Netzwerk}
427
428 Das \emph{bitone Mergesort}-Netzwerk ($\operatorname{BS}(n)$) ist ein
429 Sortiernetzwerk, das 1968 von \emph{Kenneth~E. Batcher} in~\cite{B1968}
430 veröffentlicht wurde. Es ist deutlich effizienter als das
431 Odd-Even-Transposi\-tionsort-Netzwerk -- sowohl in Bezug auf die Anzahl der
432 Komparatoren als auch bezüglich der benötigten Zeit, also der Anzahl der
433 Schichten.
434
435 Das Sortiernetzwerk basiert auf einem Komparatornetzwerk, welches zwei
436 sortierte Listen zusammenfügen (englisch: \textit{to~merge}) kann. Dieser
437 \emph{„bitone Mischer“} (englisch: \textit{bitonic merger}) genannte Baustein
438 verleiht dem Sortiernetzwerk seinen Namen.
439
440 Da das Sortiernetzwerk rekursiv definiert ist, betrachten wir hier nur die
441 Instanzen des Netzwerks, deren Leitungszahl $n = 2^t$ eine Zweierpotenz ist.
442 Es ist jedoch möglich das Sortiernetzwerk für beliebige~$n$ zu erzeugen.
443
444 \subsubsection{Der bitone Mischer}\label{sect:der_bitone_mischer}
445
446 Das \emph{bitone Mergesort}-Netzwerk basiert auf dem sogenannten \emph{bitonen
447 Mischer} $\operatorname{BM}(n)$, einem Kom\-parator-Netzwerk, das eine
448 beliebige \emph{bitone Folge} in eine sortierte Listen umordnen kann. Eine
449 \emph{bitone Folge} ist eine monoton steigende Folge gefolgt von einer monoton
450 absteigenden Folge, oder ein zyklischer Shift davon.
451 Abbildung~\ref{fig:beispiel-biton} zeigt die vier prinzipiellen Möglichkeiten
452 die durch zyklische Shifts entstehen können. Die wichtigsten Varianten für das
453 \emph{bitone Mergesort}-Netzwerk zeigen die
454 Abbildungen~\ref{fig:beispiel-biton-0} und~\ref{fig:beispiel-biton-1}. Sie
455 erhält man, wenn man eine aufsteigend und eine absteigend sortierte Liste
456 aneinanderhängt. Bei den anderen beiden Formen ist wichtig zu beachten, dass
457 das letzte Element nicht größer (Abbildung~\ref{fig:beispiel-biton-2}) bzw.
458 kleiner (Abbildung~\ref{fig:beispiel-biton-3}) als das erste Element der Folge
459 sein darf.
460
461 \begin{figure}
462   \centering
463   \subfigure[aufsteigend, absteigend]{\input{images/beispiel-biton-0.tex}\label{fig:beispiel-biton-0}}
464   \subfigure[absteigend, aufsteigend]{\input{images/beispiel-biton-1.tex}\label{fig:beispiel-biton-1}}
465   \subfigure[aufsteigend, absteigend, aufsteigend]{\input{images/beispiel-biton-2.tex}\label{fig:beispiel-biton-2}}
466   \subfigure[absteigend, aufsteigend, absteigend]{\input{images/beispiel-biton-3.tex}\label{fig:beispiel-biton-3}}
467   \caption{Beispiele bitoner Folgen.}
468   \label{fig:beispiel-biton}
469 \end{figure}
470
471 \begin{figure}
472   \centering
473   \subfigure[normal]{\input{images/bitonic-merge.tex}\label{fig:bitonic-merge-normal}}
474   \qquad
475   \subfigure[trichter]{\input{images/bitonic-merge-trichter.tex}\label{fig:bitonic-merge-tricheter}}
476   \caption{Schematischer Aufbau des bitonen Mischers: Jedes Element der
477   aufsteigenden Folge $u_0, u_1, \ldots$ wird mit dem entsprechenden Element
478   der absteigend sortierten Folge $v_0, v_1, \ldots$ verglichen. Die beiden
479   resultierenden Teilfolgen sind wiederum biton.}
480   \label{fig:bitonic-merge-schema}
481 \end{figure}
482
483 Der Mischer funktioniert folgendermaßen: Gegeben sind zwei Folgen mit je
484 ${m = \frac{n}{2}}$ Elementen, $U = \left(u_0, u_1, \ldots, u_{m-1}\right)$ und
485 $V = \left(v_0, v_1, \ldots, v_{m-1}\right)$. Die Folge $U$ sei aufsteigend
486 sortiert, die Folge $V$ sei absteigend sortiert:
487 \begin{eqnarray}
488  u_0 \leqq u_1 \leqq &\ldots& \leqq u_{m-1} \\
489  v_0 \geqq v_1 \geqq &\ldots& \geqq v_{m-1}
490 \end{eqnarray}
491 Im ersten Schritt werden nun jeweils die Elemente an den gleichen relativen
492 Positionen verglichen und ggf. vertauscht:
493 \begin{equation}
494 u_i \longleftrightarrow v_i, \quad 0 \leqq i < m
495 \end{equation}
496 Sei $j \in \{0 \ldots m\}$ der Index der ersten Elemente $u_j$ und $v_j$, die
497 durch den gemeinsamen Komparator vertauscht werden. Unter der Annahme, dass
498 Elemente nur vertauscht werden wenn, sie ungleich sind, muss ${u_j > v_j}$
499 gelten. Mit $u_j \leqq u_{j+1}$ und $v_j \geqq v_{j+1}$ folgt daraus $u_{j+1}
500 > v_{j+1}$. Es werden also alle Elemente $u_k$ und $v_k$ mit $k \geqq j$
501 vertauscht. $j = m$ bezeichnet den Fall, in dem das größte Element der
502 "`linken"' Folge, $u_{m-1}$, kleiner ist als das kleinste Element der
503 "`rechten"' Folge, $v_{m-1}$. Daraus folgt, dass das Resultat in zwei bitone
504 Folgen aufteilen lässt: Eine aufsteigende~/ absteigende Folge und eine
505 absteigende~/ aufsteigende Folge. Abbildung~\ref{fig:bitonic-merge-normal}
506 zeigt die Situationen vor und nach diesem Schritt des Mischers.
507
508 Um die Folge vollständig zu sortieren, müssen anschließend die beiden
509 resultierenden bitonen Folgen sortiert werden. Die geschieht ebenfalls
510 mithilfe des bitonen Mischers, mit zwei Instanzen von
511 $\operatorname{BM}(\frac{n}{2})$. Diese rekursive Definition endet mit dem
512 bitonen Mischer mit zwei Leitungen, $\operatorname{BM}(2)$, der als
513 Komparator-Netzwerk mit einem Komparator zwischen den beiden Leitungen
514 definiert ist.
515
516 Der bitonen Mischer kann auch zwei aufsteigende Folgen sortieren. Dazu ist
517 lediglich eine etwas modifizierte Vergleichs-Kaskade im ersten Schritt
518 notwendig. Die folgenden, kleineren Mischer erhalten als Eingabe wieder eine
519 „echte“ bitone Folge. Abbildung~\ref{fig:bitonic-merge-tricheter} zeigt das
520 Schema des bitonen Mischers für zwei aufsteigend sortierte Foglen. Durch das
521 Umdrehen einer Folge verändert sich das Muster der Komparatoren ein wenig:
522 Statt an eine Treppe erinnert das Muster nun an einen Trichter.
523
524 Da sich die Anzahl der Leitungen in jedem Rekursionsschritt halbiert, endet
525 die Rekursion nach $\log(n)$~Schritten. In jedem Rekursionsschritt werden
526 $\frac{n}{2}$~Komparatoren eingefügt, so dass der gesamte Mischer aus
527 $\frac{1}{2} n \log(n) = \mathcal{O}\left(n \log(n)\right)$~Komparatoren
528 besteht, die in $\log(n)$~Schichten angeordnet werden können.
529
530 \subsubsection{Das bitone Mergesort-Netzwerk}
531
532 Ebenso wie der bitone Mischer $\operatorname{BM}(n)$ ist auch das \emph{bitone
533 Mergesort-Netzwerk} $\operatorname{BS}(n)$ rekursiv definiert. Es setzt sich
534 zusammen aus zwei Instanzen des bitonen Mergesort-Netzwerks halber Größe,
535 $\operatorname{BS}(\frac{n}{2})$, für je die Hälfte der Eingänge, sowie dem
536 bitonen Mischer für $n$~Leitungen, $\operatorname{BM}(n)$. Das Rekursionsende
537 ist das bitone Mergesort-Netzwerk mit nur einer Leitung,
538 $\operatorname{BS}(1)$, welches als leeres Komparatornetzwerk definiert ist. 
539 Entsprechend sind die Komparatornetzwerke $\operatorname{BM}(2)$ und
540 $\operatorname{BS}(2)$ identisch.
541
542 Bei der Konstruktion kommt die trichterförmige Anordnung der Komparatoren
543 (Abbildung~\ref{fig:bitonic-merge-tricheter}) gelegen, weil so die beiden
544 rekursiven Sortiernetzwerke in die gleiche Richtung sortieren können und so
545 alle Komparatoren in die gleiche Richtung zeigen.
546
547 \begin{figure}
548   \begin{center}
549   \input{images/batcher-8.tex}
550   \end{center}
551   \caption{\bs{8}, Batchers \emph{bitones Mergesort}-Netzwerk für acht
552   Eingänge. Markiert sind die beiden Instanzen von \bs{4} (rot), die beiden
553   bitonen Mischer~\bm{4} (blau) und die Komparatoren, die im letzten
554   rekursiven Schritt hinzugefügt wurden (grün).}
555   \label{fig:bitonic-08}
556 \end{figure}
557
558 Das konkrete Netzwerk~$\operatorname{BS}(8)$ ist in
559 Abbildung~\ref{fig:bitonic-08} zu sehen. Eingezeichnet sind ebenfalls die
560 beiden Instanzen des Netzwerks~$\operatorname{BS}(4)$ (rot) sowie der bitone
561 Mischer~$\operatorname{BM}(8)$ (blau). Die trichterförmige Komparator-Kaskade,
562 die die bitone Eingabefolge in zwei bitone Ausgabefolgen transformiert, ist
563 grün hinterlegt.
564
565 Das \emph{bitone Mergesort-Netzwerk} $\operatorname{BS}(8)$ besteht aus
566 $\frac{1}{4} n \log(n) \log(n+1) = \mathcal{O}\left(n (log (n))^2\right)$
567 Komparatoren, die in $\frac{1}{2} \log(n) \log(n+1) = \mathcal{O}(\log(n))$
568 Schichten angeordnet sind.
569
570 \subsection{Das Odd-Even-Mergesort-Netzwerk}
571
572 Obwohl der Name ähnlich klingt, haben das \emph{Odd-Even-Mergesort-Netzwerk}
573 (OES) und das \emph{Odd-Even-Transpositionsort-Netzwerk} (siehe
574 Abschnitt~\ref{sect:odd_even_transpositionsort}) wenig gemein. Vielmehr ist
575 OES dem \emph{bitonen Mergesort-Netzwerk}, das im vorherigen Abschnitt
576 vorgestellt wurde, ähnlich: Auch dieses Sortiernetzwerk ist von
577 \textit{Kenneth~E. Batcher} gefunden worden und ist ebenfalls in~\cite{B1968}
578 beschrieben und initial analysiert worden. Eine weitere Gemeinsamkeit besteht
579 darin, dass es ebenfalls rekursiv durch einen Mischer definiert ist.
580
581 \subsubsection{Der \emph{Odd-Even}-Mischer}\label{sect:der_odd_even_mischer}
582
583 Der \emph{Odd-Even}-Mischer $\operatorname{OEM}(n,m)$ ist ein
584 Komperatornetzwerk, dass zwei sortierte Folgen mit $n$ beziehungsweise $m$
585 Elementen zu einer sortierten Ausgabefolge mit $N = n+m$~Elementen
586 zusammenfügen kann. Dabei kommt es mit weniger Vergleichen aus als der
587 \emph{bitone Mischer}, der im Abschnitt~\ref{sect:der_bitone_mischer}
588 vorgestellt wurde. Allerdings benötigt der \emph{Odd-Even}-Mischer unter
589 Umständen mehr Schichten als der \emph{bitone Mischer}.~\cite{KNUTH}
590
591 Der \emph{Odd-Even}-Mischer selbst ist ebenfalls rekursiv aufgebaut: Die
592 Eingabe für den Mischer mit $N = n + m$ Leitungen besteht aus den beiden
593 sortierten Folgen $U = \left(u_0, u_1, \ldots, u_{n-1}\right)$ und
594 $V = \left(v_0, v_1, \ldots, v_{m-1}\right)$. Die gesamte Eingabe sei
595 $W = \left(w_0, w_1, \ldots, w_{N-1}\right)$ mit:
596 \begin{equation}
597 w_i = \left\{ \begin{array}{ll}
598         u_i,     & i < n \\
599         v_{i-n}, & i \geqq n
600       \end{array} \right.,
601       \quad 0 \leqq i < N
602 \end{equation}
603
604 \begin{figure}
605   \begin{center}
606   \input{images/oe-merge.tex}
607   \end{center}
608   \caption{Schematischer Aufbau des {\em Odd-Even} Mischers. Im Vergleich zum
609   bitonen Mischer für Acht kommt dieses Schema mit einem Komparator weniger
610   aus. Der Effekt wird duch den rekursiven Aufbau noch verstärkt.}
611   \label{fig:oe-merge}
612 \end{figure}
613
614 Diese werden in insgesamt vier sortierte Folgen aufgeteilt, je eine Liste der
615 geraden Indizes und je eine Liste der ungeraden Indizes.
616 \begin{eqnarray}
617   U_{\textrm{gerade}}   &=& \left(u_0, u_2, u_4, \ldots\right) \\
618   U_{\textrm{ungerade}} &=& \left(u_1, u_3, u_5, \ldots\right) \\
619   V_{\textrm{gerade}}   &=& \left(v_0, v_2, u_4, \ldots\right) \\
620   V_{\textrm{ungerade}} &=& \left(v_1, v_3, u_5, \ldots\right)
621 \end{eqnarray}
622
623 Die geraden Folgen $U_{\textrm{gerade}}$ und $V_{\textrm{gerade}}$ bzw. die
624 ungeraden Folgen $U_{\textrm{ungerade}}$ und $V_{\textrm{ungerade}}$ werden
625 rekursiv von kleineren \emph{Odd-Even}-Mischern zusammengefügt, so dass sich am
626 Ausgang der Mischer die Folgen
627 \begin{eqnarray}
628   W_{\textrm{gerade}}   &=& \left(w_0, w_2, w_4, \ldots\right) \\
629   W_{\textrm{ungerade}} &=& \left(w_1, w_3, w_5, \ldots\right)
630 \end{eqnarray}
631 ergeben.
632
633 Anschließend werden die Komparatoren zwischen benachbarten Leitungen
634 hinzugefügt,
635 \begin{equation}
636   w_{2i-1} \longleftrightarrow w_{2i}, \quad 1 \leqq i < \frac{N}{2}
637 \end{equation}
638 die die Folge~$W$ sortieren. Den schematischen Aufbau des
639 \emph{Odd-Even}-Mischers zeigt Abbildung~\ref{fig:oe-merge}.
640
641 Leider bricht die Rekursion nicht so schön ab, wie das beim {\em bitonen
642 Mischer} der Fall gewesen ist. Insbesondere für ${n = m = 1}$ würde --
643 entsprechend der Konstruktionsvorschrift -- ein leeres Netzwerk entstehen, was
644 offensichtlich nicht korrekt wäre. Die Abbruchbedingungen für den rekursiven
645 Aufbau lauten:
646 \begin{itemize}
647   \item Falls ${n = 0}$ oder ${m = 0}$: Das Netzwerk ist leer.
648   \item Falls ${n = 1}$ und ${m = 1}$: Das Netzwerk besteht aus einem
649   einzelnen Komparator.
650 \end{itemize}
651
652 Dass die resultierende Folge sortiert ist, lässt sich mit dem
653 {\em 0-1-Prinzip} zeigen:
654 Da $U$ und $V$ sortiert sind, ist die Anzahl der Nullen in den geraden
655 Teilfolgen, $U_{\textrm{gerade}}$ bzw. $V_{\textrm{gerade}}$, größer oder
656 gleich der Anzahl der Nullen in den ungeraden Teilfolgen
657 $U_{\textrm{ungerade}}$ bzw. $V_{\textrm{ungerade}}$ --~die Einsen verhalten
658 sich entsprechend umgekehrt. Das trifft demnach auch auf die Folgen
659 $W_{\textrm{gerade}}$ und $W_{\textrm{ungerade}}$ entsprechend zu:
660 \begin{eqnarray}
661   \left|W_{\textrm{gerade}}\right|_0
662   &=& \left|U_{\textrm{gerade}}\right|_0
663     + \left|V_{\textrm{gerade}}\right|_0
664    =  \left\lceil \frac{1}{2} \left|U\right|_0 \right\rceil
665    +  \left\lceil \frac{1}{2} \left|V\right|_0 \right\rceil \\
666   \left|W_{\textrm{ungerade}}\right|_0
667   &=& \left|U_{\textrm{ungerade}}\right|_0
668     + \left|V_{\textrm{ungerade}}\right|_0
669    =  \left\lfloor \frac{1}{2} \left|U\right|_0 \right\rfloor
670    +  \left\lfloor \frac{1}{2} \left|V\right|_0 \right\rfloor
671 \end{eqnarray}
672 Daraus folgt, dass $W_{\textrm{gerade}}$ $0$, $1$ oder $2$ Nullen mehr enthält
673 als $W_{\textrm{ungerade}}$. In den ersten beiden Fällen ist die "`verzahnte"'
674 Ausgabe der beiden kleineren Mischer bereits sortiert. Nur im letzten Fall,
675 wenn $W_{\textrm{gerade}}$ zwei Nullen mehr enthählt als
676 $W_{\textrm{ungerade}}$, muss genau eine Vertauschung stattfinden, um die
677 Ausgabe zu sortieren. Diese wird von den Komparatoren, die benachbarte
678 Leitungen miteinander vergleichen, ausgeführt. Die jeweiligen Situationen sind
679 in Abbildung~\ref{fig:oe-post-recursive} dargestellt.
680
681 \begin{figure}
682   \centering
683   \subfigure[$\left|W_{\textrm{gerade}}\right|_0 - \left|W_{\textrm{ungerade}}\right|_0 = 0$]{\input{images/oe-post-recursive-diff0.tex}}
684   \qquad
685   \subfigure[$\left|W_{\textrm{gerade}}\right|_0 - \left|W_{\textrm{ungerade}}\right|_0 = 1$]{\input{images/oe-post-recursive-diff1.tex}}
686   \qquad
687   \subfigure[$\left|W_{\textrm{gerade}}\right|_0 - \left|W_{\textrm{ungerade}}\right|_0 = 2$]{\input{images/oe-post-recursive-diff2.tex}}
688   \caption{Die drei Situationen, die nach dem Verzahnen der Ausgaben der
689   kleineren \emph{Odd-Even}-Mischer entstehen können. Ist die Differenz der
690   Anzahl der Nullen gleich $0$ oder $1$, ist die Folge bereits sortiert. Im
691   letzten Fall stellt einer der Komparatoren sicher, dass das Ergebnis
692   sortiert ist.}
693   \label{fig:oe-post-recursive}
694 \end{figure}
695
696 Da die Teilfolgen $U$ und $V$ in jedem Rekursionsschritt etwa halbiert werden,
697 bricht die Rekursion nach $\mathcal{O}\left(\log (n) + \log (m)\right)$
698 Schritten ab. Die exakte Anzahl der benötigten Rekursionsschritte (und damit
699 Schichten im Mischer-Netzwerk), hängt von der Längeren der beiden
700 Eingabefolgen ab und beträgt $1 + \lceil \log\left(\max(n, m)\right) \rceil$.
701
702 Die Anzahl der Komparatoren $K(n,m)$, die $\operatorname{OEM}(n,m)$ im
703 allgemeinen Fall verwendet, ist Gemäß der rekursiven Definition in
704 Abhängigkeit der Länge der Eingabefolgen, $n$ und $m$:
705 \begin{displaymath}
706   K(n,m) = \left\{ \begin{array}{ll}
707     nm, & \mathrm{falls} \quad nm \leqq 1 \\
708     K\left(\left\lceil \frac{n}{2} \right\rceil, \left\lceil \frac{m}{2} \right\rceil\right)
709     + K\left(\left\lfloor \frac{n}{2} \right\rfloor, \left\lfloor \frac{m}{2} \right\rfloor\right)
710     + \left\lfloor \frac{1}{2} (m + n - 1) \right\rfloor & \mathrm{falls} \quad nm > 1
711   \end{array} \right.
712 \end{displaymath}
713 Leider ist es schwierig, diese allgemeine Formel in einer geschlossenen Form
714 anzugeben. Aus der Anzahl der Rekursionsschritte ist jedoch leicht erkennbar,
715 dass $K(n,m)$ in $\mathcal{O}(N \log (N))$ enthalten ist.
716
717 Für den wichtigen Spezialfall, dass $n = m = 2^{t-1}$, lässt sich die Anzahl
718 der Komparatoren im Vergleich zum \emph{bitonen Mischer} angeben: Der erste
719 Rekursionsschritt der OEM-Konstruktion fügt
720 $\left\lfloor \frac{1}{2} (m + n - 1) \right\rfloor = \frac{N}{2} - 1$
721 Komparatoren ein -- einen Komparator weniger als der \emph{bitone Mischer} in
722 diesem Schritt. Das selbe gilt für die rekursiv verwendeten kleineren Mischer,
723 $\operatorname{OEM}(\frac{n}{2}, \frac{n}{2})$ und so weiter bis
724 einschließlich $\operatorname{OEM}(2, 2)$, von denen es $2, 4, \dots,
725 \frac{N}{4} = 2^{\log(N)-2}$ Instanzen gibt. Insgesamt werden
726 \begin{displaymath}
727   \sum_{i=0}^{\log(N)-2} 2^i = 2^{\log(N) - 1} - 1 = \frac{N}{2} - 1 = n - 1
728 \end{displaymath}
729 Komparatoren eingespart. Damit ergibt sich
730 \begin{displaymath}
731   K\left(n = 2^{t-1}, n = 2^{t-1}\right) = \frac{1}{2} N \log(N) - \frac{N}{2} + 1
732 \end{displaymath}
733 für die Anzahl der Komparatoren, die von $\operatorname{OEM}(N = 2^t)$
734 benötigt werden.
735
736 \subsubsection{Das Odd-Even-Mergesort-Netzwerk}
737
738 Das \emph{Odd-Even-Mergesort-Netzwerk} $\operatorname{OES}(n)$ besteht --~wie
739 das \emph{bitone Mergesort-Netzwerk}~-- rekursiv aus kleineren Varianten von
740 sich selbst und einem abschließenden \emph{Odd-Even}-Mischer. Die
741 effizientesten Sortiernetzwerke in Bezug auf Komparator- und Schichtzahl
742 entstehen, wenn die Anzahl der Leitungen jeweils halbiert wird. Somit besteht
743 $\operatorname{OES}(n)$ aus
744 $\operatorname{OES}\left(\left\lceil\frac{n}{2}\right\rceil\right)$,
745 $\operatorname{OES}\left(\left\lfloor\frac{n}{2}\right\rfloor\right)$
746 und $\operatorname{OEM}\left(\left\lceil\frac{n}{2}\right\rceil,
747 \left\lfloor\frac{n}{2}\right\rfloor\right)$. Die Rekursion endet mit
748 $\operatorname{OES}(1)$ und $\operatorname{OES}(0)$, die als leere
749 Komparatornetzwerke definiert sind.
750
751 \begin{figure}
752   \begin{center}
753   \input{images/oe-mergesort-8.tex}
754   \end{center}
755   \caption{Das {\em Odd-Even-Mergesort-Netzwerk} für acht Eingänge. Markiert
756   sind die Instanzen von $\operatorname{OES}(4)$ (rot), die beiden
757   \emph{Odd-Even}-Mischer $\operatorname{OEM}(4)$ für gerade und ungerade
758   Leitungen (blau) und die im ersten Rekursionsschritt hinzugefügten
759   Komparatoren zwischen benachbarten Leitungen (grün).}
760   \label{fig:odd-even-mergesort-08}
761 \end{figure}
762
763 In Abbildung~\ref{fig:odd-even-mergesort-08} ist das konkrete Sortiernetzwerk
764 $\operatorname{OES}(8)$ zu sehen. Rot markiert sind die beiden rekursiven
765 Instanzen $\operatorname{OES}(4)$. Die blauen und der grüne Block stellen den
766 \emph{Odd-Even}-Mischer für acht Leitungen dar: Die beiden blauen Blöcke sind
767 die rekursiven Instanzen von $\operatorname{OEM}(4)$, der grüne Block markiert
768 die Komparatoren, die in ersten Rekursionsschritt hinzugefügt werden.
769
770 Im Allgemeinen ist die Anzahl der Komparatoren, die vom
771 \emph{Odd-Even-Mergesort-Netz\-werk} verwendet wird, $k(n)$, direkt aus der
772 Definition beziehungsweise der Konstruktionsanleitung abzulesen:
773 \begin{displaymath}
774   k(n) = k\left(\left\lceil\frac{n}{2}\right\rceil\right)
775        + k\left(\left\lfloor\frac{n}{2}\right\rfloor\right)
776        + K\left(\left\lceil\frac{n}{2}\right\rceil, \left\lfloor\frac{n}{2}\right\rfloor\right)
777 \end{displaymath}
778 Eine geschlossene Form dieser Formel ist schon alleine deshalb schwierig, weil
779 sie für $K(n,m)$ schwierig anzugeben ist. Es ist allerdings bekannt, dass
780 $k(n)$ in $\mathcal{O}\left(n \left(\log (n)\right)^2\right)$ enthalten ist.
781
782 Für den wichtigen Spezialfall, dass $n = 2^t$ eine Zweierpotenz ist, kann die
783 Anzahl der Komparatoren wieder explizit angegeben werden. \textit{Kenneth
784 Batcher} zeigt in~\cite{B1968}, dass in diesem Fall
785 \begin{displaymath}
786   k(n = 2^t) = \frac{1}{4} n \left(\log (n)\right)^2 - \frac{1}{4}n\log(n) + n - 1
787 \end{displaymath}
788 gilt.
789
790 % gnuplot:
791 % 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))
792 % oem1(n) = oem(ceil(.5*n),floor(.5*n))
793 % oes(n) = (n <= 1.0) ? 0 : oes(ceil(0.5*n)) + oes(floor(0.5*n)) + oem1(n)
794
795 %\begin{itemize}
796 %\item Pairwise sorting-network
797 %\end{itemize}
798
799 \newpage
800 \section{Transformation von Sortiernetzwerken}
801 \label{sect:tranformation}
802
803 \subsection{Komprimieren}
804
805 Komparatoren, die unterschiedliche Leitungen miteinander vergleichen, können
806 gleichzeitig ausgewertet werden, wie bereits in
807 Abschnitt~\ref{sect:einleitung_sortiernetzwerke} beschrieben. Durch manche
808 Transformationen, insbesondere das Entfernen einer Leitung, das in
809 Abschnitt~\ref{sect:leitungen_entfernen} beschrieben wird, kann es vorkommen,
810 dass die Komparatoren eines Sortiernetzwerks nicht mehr in der
811 kleinstmöglichen Anzahl von \emph{Schichten} angeordnet sind. Unter
812 \emph{Komprimierung} wird eine (Neu-)Gruppierung der Komparatoren verstanden,
813 die jeden Komparator so früh wie möglich ausführt. So entsteht die
814 kleinstmögliche Anzahl von \emph{Schichten}, in die sich ein Sortiernetzwerk
815 unterteilen lässt.
816
817 Diese Anzahl ist insbesondere beim automatisierten Bewerten von
818 Komparatornetzwerken interessant, wie in Abschnitt~\ref{sect:bewertung}
819 beschrieben. Die Anzahl der Schichten kann künstlich vergrößert werden, indem
820 Komparatoren später angewandt werden. Deshalb sollte vor einer Bewertung, die
821 die Anzahl der Schichten als Bewertungskriterium verwendet, immer eine
822 Komprimierung durchgeführt werden.
823
824 \subsection{Normalisieren}
825 \label{sect:normalisieren}
826
827 \begin{figure}
828   \centering
829   \subfigure[$S(8)$ (nach Konstruktion)]{\input{images/batcher-8-nonstd.tex}\label{fig:bitonic-nonstd}}
830   \subfigure[$S(8)$ (normalisiert)]{\input{images/batcher-8-std.tex}\label{fig:bitonic-std}}
831   \caption{Jedes Sortiernetzwerk kann in ein Standard-Sortiernetzwerk
832   transformiert werden. Gezeigt ist das bitone Sortiernetzwerk nach der
833   intuitiven Konstruktion und die normalisierte Variante.}
834   \label{fig:beispiel_normalisieren}
835 \end{figure}
836
837 Ein \emph{Standard-Sortiernetzwerk} oder \emph{normalisiertes Sortiernetzwerk}
838 ist ein Sortiernetzwerk, dessen Komparatoren alle in die selbe Richtung
839 zeigen. Jedes Sortiernetzwerk kann in eine normaliesierte Variante
840 transformiert werden. Dazu gibt beispielsweise \emph{Donald~E. Knuth}
841 in~\cite{KNUTH} einen Algorithmus an.
842
843 Abbildung~\ref{fig:beispiel_normalisieren} zeigt das das
844 bitone Sortiernetzwerk in zwei Varianten. Abbildung~\ref{fig:bitonic-nonstd}
845 zeigt das Netzwerk nach der Konstruktionsvorschrift, siehe auch
846 Abbildung~\ref{fig:bitonic-merge-normal}: In den ersten drei Schichten werden
847 die unter und die obere Hälfte gegenläufig sortiert. Das heißt dass nach drei
848 Schritten die eine Hälfte auf- und die andere Hälfte absteigend sortiert ist. 
849 In den Schichten~4 bis~6 folgt der bitone Mischer entsprechend der rekursiven
850 Definition.
851
852 In Abbildung~\ref{fig:bitonic-std} ist die normalisierte Version des bitonen
853 Mergesort-Netzwerks zu sehen. Alle Komparatoren zeigen hier in die gleiche
854 Richtung. Statt dem typischen "`Treppenmuster"' sind abwechselnd das Treppen-
855 und das Trichtermuster zu sehen.
856
857 \subsection{Zwei Netzwerke kombinieren}
858
859 Um Sortiernetzwerke als \emph{Individuen} evolutionärer Algorithmen verwenden
860 zu können, muss es möglich sein, zwei Sortiernetzwerke zu einem neuen
861 Sortiernetzwerk zusammenzufassen.
862
863 Wir haben diese Technik in den vorangegangen Abschnitten bereits verwendet,
864 beispielsweise um zwei \emph{bitone Mergesort-Netzwerke} mit jeweils der
865 halben Leitungszahl, $\operatorname{BS}\left(\frac{n}{2}\right)$, zu einem
866 einzigen Sortiernetzwerk $\operatorname{BS}(n)$ zu kombinieren. Auch das
867 \emph{Odd-Even-Mergesort-Netzwerk} $\operatorname{OES}(n)$ wurde auf diese Art
868 und Weise rekursiv aufgebaut.
869
870 Die vorgestellten \emph{Mischer} erwarten als Eingabe zwei bereits sortierte
871 Folgen. \emph{Wie} diese Folgen sortiert wurden, ist unerheblich. Entsprechend
872 können wir beliebige Sortiernetzwerke einsetzen, um die beiden Eingabefolgen
873 zu sortieren, und die Ausgaben mit einem der beschriebenen Mischer
874 zusammenfügen.
875
876 Beispielsweise kann man die Ausgabe von zwei \emph{bitonen
877 Mergesort-Netzwerken} $\operatorname{BS}(8)$ mit je acht Leitungen mit dem
878 \emph{Odd-Even-Merge} $\operatorname{OEM(8,8)}$ zu einer sortierten
879 Gesamtfolge zusammenfügen. Das resultierende Sortiernetzwerk besitzt
880 73~Komparatoren (zum Vergleich: $\operatorname{BS}(16)$ benötigt
881 80~Komparatoren, $\operatorname{OES}(16)$ nur 63).
882
883 Verbesserungen in der Anzahl der benötigten Komparatoren beziehungsweise der
884 Schichten eines „kleinen“ Sortiernetzwerks übertragen sich direkt auf das
885 resultierende Gesamtnetzwerk. Das \emph{Odd-Even-Mergesort-Netzwerk}
886 $\operatorname{OES}(9)$ benötigt beispielsweise 26~Komparatoren, die in in
887 neun Schichten angeordnet sind. Es sind allerdings Sortiernetzwerke mit neun
888 Eingängen bekannt, die lediglich 25~Komparatoren in sieben Schichten
889 benötigen. Kombiniert man zwei dieser Netzwerke mit dem
890 \emph{Odd-Even}-Mischer erhält man ein Sortiernetzwerk mit 18~Eingängen, das
891 80~Komparatoren in 11~Schichten benötigt -- $\operatorname{OES}(18)$ benötigt
892 82~Komparatoren in 13~Schichten. Damit ist das resultierende Netzwerk so
893 schnell wie das Sortiernetzwerk mit 18~Eingängen, das \textit{Sherenaz~W.
894 Al-Haj Baddar} und \textit{Kenneth~E. Batcher} in ihrer Arbeit „An 11-Step
895 Sorting Network for 18~Elements“~\cite{BB2009} vorstellen, benötigt aber
896 6~Komparatoren weniger.
897
898 Das Zusammenfassen von zwei Sortiernetzwerken durch Hintereinanderausführung
899 ist nicht sinnvoll: Da die Ausgabe des ersten Sortiernetzwerks bereits
900 sortiert ist, ist das zweite Sortiernetzwerk überflüssig. Eine
901 Aneinanderreihung der Art „die ersten $x$~Schichten des einen, dann die
902 letzten $y$~Schichten des anderen Sortiernetzwerks“ zerstören im Allgemeinen
903 die Sortiereigenschaft. Die Sortiereigenschaft des resultierenden
904 Komparatornetzwerks müsste überprüft werden, was nach heutigem Wissensstand
905 nur mit exponentiellem Aufwand möglich ist.
906
907 \subsection{Leitungen entfernen}
908 \label{sect:leitungen_entfernen}
909
910 Im vorherigen Abschnitt haben wir gesehen, dass es mithilfe von
911 \emph{Mischern} möglich ist, aus zwei Sortiernetzwerken mit je $n$~Eingängen
912 ein neues Sortiernetzwerk mit $2n$~Eingängen zu erzeugen. Für einen
913 beabsichtigen \emph{evolutionären Algorithmus} ist es jedoch notwendig, dass
914 sich die Anzahl der Eingänge nicht verändert. Das heißt, dass wir wieder ein
915 Sortiernetzwerk mit $n$~Eingängen erhalten müssen.
916
917 Man kann ein gegebenes Sortiernetzwerk mit $n$~Eingängen auf ein
918 Sortiernetzwerk mit ${n-1}$~Leitungen verkleinern, indem man eine Leitung
919 „eliminiert“. Dazu nehmen wir an, dass das Minimum oder das Maximum an einem
920 bestimmten Eingang anliegt. Der Weg, den das Minimum beziehungsweise das Maxim
921 durch das Sortiernetzwerk nimmt, ist eindeutig bestimmt und endet an einem der
922 „Ränder“, also auf der Leitung mit dem höchsten oder dem niedrigsten Index.
923 Insbesondere ist bekannt, welche Komparatoren „berührt“ werden und welche
924 dafür sorgen, dass der Wert die Leitung gewechselt, da das Minimum jeden
925 Vergleich „verliert“ und das Maximum jeden Vergleich „gewinnt“. Die
926 Abbildung~\ref{fig:oe-transposition-cut0} zeigt den Weg eines Maximums durch
927 das {\em Odd-Even-Transpositionsort-Netzwerk}.
928
929 \begin{figure}
930   \centering
931   \subfigure[Auf der Leitung~4 wird $-\infty$ angelegt. Dadurch ist der Pfad
932   durch das Sortiernetzwerk eindeutig festgelegt.]{\input{images/oe-transposition-cut0.tex}\label{fig:oe-transposition-cut0}}
933   \subfigure[Komparatoren, die einen wechsel der Leitungen bewirken, werden
934   durch sich kreuzende Leitungen ersetzt.]{\input{images/oe-transposition-cut1.tex}\label{fig:oe-transposition-cut1}}
935   \subfigure[Leitung~4 wurde entfernt. Übrig bleibt ein Sortiernetzwerk mit
936   7~Leitungen.]{\input{images/oe-transposition-cut2.tex}\label{fig:oe-transposition-cut2}}
937   \subfigure[Die Leitungen wurden wieder gerade eingezeichnet und die
938   Komparatoren regelmäßig angeordnet. Blau eingezeichnet ist \oet{7}.]{\input{images/oe-transposition-cut3.tex}\label{fig:oe-transposition-cut3}}
939   \caption{Eine Leitung wird aus dem
940   \emph{Odd-Even-Transpositionsort}-Netzwerk \oet{8} entfernt: Auf der rot
941   markierten Leitung wird $-\infty$ angelegt. Da der Wert bei jedem Komparator
942   am unteren Ende herauskommt, ist der Pfad fest vorgegeben. Da die restlichen
943   Werte trotzdem noch richtig sortiert werden müssen, kann dieser Pfad
944   herausgetrennt werden. In der letzten Abbildung ist \oet{7} markiert.}
945   \label{fig:oe-transposition-cut}
946 \end{figure}
947
948 Im nächsten Schritt werden alle beteiligten Komparatoren gelöscht bzw.
949 ersetzt: Komparatoren, die {\em nicht} zu einem Wechsel der Leitung geführt
950 haben, werden ersatzlos gelöscht. Diese Komparatoren sind in
951 Abbildung~\ref{fig:oe-transposition-cut0} grün markiert. Die Komparatoren, die
952 zum Wechsel der Leitung geführt haben, werden durch sich kreuzende Leitungen
953 ersetzt. Das Resultat ist eine Leitung, auf der das Minimum beziehungsweise
954 das Maximum angenommen wird, die an unterster oder oberster Stelle endet und
955 auf die keine Komparatoren mehr berührt
956 (Abbildung~\ref{fig:oe-transposition-cut1}).
957
958 Die Werte auf den verbleibenden $(n-1)$~Leitungen müssen vom restlichen
959 Komparatornetzwerk immernoch sortiert werden: Wir haben lediglich die Position
960 des Minimums oder des Maximums angenommen. Ein Sortiernetzwerk muss die
961 Eingabe sortieren, egal auf welcher Leitung das Minimum~/ das Maximum liegt.
962 Wir haben lediglich angefangen, das Sortiernetzwerk unter diese Annahme
963 auszuwerten -- über die verbleibenden Eingänge haben wir keine Aussage
964 getroffen. Entsprechend müssen die verbleibenden Ausgänge eine sortierte Liste
965 mit $(n-1)$~Elementen darstellen.
966
967 Wenn man die Minimum- beziehungsweise Maximum-Leitung entfernt, wie in
968 Abbildung~\ref{fig:oe-transposition-cut2} dargestellt, bleibt das
969 Sortiernetzwerk für $(n-1)$~Leitungen übrig. Je nachdem, ob auf einer Leitung
970 ein Minimum oder ein Maximum angenommen wird, bezeichnen wir das eliminieren
971 einer Leitung als \emph{Minimum-Schnitt} beziehungsweise
972 \emph{Maximum-Schnitt}.
973
974 Die letzte Abbildung, \ref{fig:oe-transposition-cut3}, zeigt das
975 Sortiernetzwerk wieder mit den üblichen geraden Leitungen und die rot
976 markierten Komparatoren wurden verschoben, so dass sich eine kompaktere
977 Darstellung ergibt. Ausserdem ist das
978 \emph{Odd-Even-Transpositionsort}-Netzwerk für sieben Werte markiert. Der
979 zusätzliche Komparator vor dem \oet{7} hat keinen Einfluss auf die Ausgabe und
980 kann entfernt werden.
981
982 Durch das Ersetzen von Komparatoren durch gekreuzte Leitungen werden häufig
983 \emph{Nicht-Standard-Sortiernetzwerke} erzeugt. Im Anschluss an einen
984 \emph{Schnitt} empfiehlt es sich deshalb, das Sortiernetzwerk zu
985 \emph{normalisieren}, wie in Abschnitt~\ref{sect:normalisieren} beschrieben.
986
987 \subsubsection{Anzahl möglicher und unterschiedlicher Schnittmuster}
988 \label{sect:anzahl_schnittmuster}
989
990 Der Eliminierungsschritt kann iterativ angewandt werden, um aus einem
991 Sortiernetzwerk mit $n$~Ein\-gängen Sortiernetzwerke mit $n-1$, $n-2$,
992 $n-3$,~\dots Eingängen zu erzeugen. Insbesondere können auf diese Art und
993 Weise Sortiernetzwerke mit $2n$~Eingängen auf Sortiernetzwerke mit
994 $n$~Eingängen reduziert werden. $k$~Minimum- und Maximum-Schnitte, die
995 nacheinander angewendet ein $n$-Sortiernetzwerk auf ein
996 ${(n-k)}$-Sortiernetz\-werk reduzieren, bezeichnen wir als
997 \emph{$k$-Schnittmuster}.
998
999 Zwei Schnittmuster heißen \emph{äquivalent} bezüglich~$S$, wenn ihre Anwendung
1000 auf das Sortiernetzwerk~$S$ das selbe Ergebnis liefert. Ansonsten heißen die
1001 Schnittmuster \emph{unterschiedlich} bezüglich~$S$. 
1002
1003 Bei einem Sortiernetzwerk mit $n$~Eingängen gibt es $2n$~Möglichkeiten eine
1004 Leitung zu entfernen: Auf jeder der $n$~Leitungen kann sowohl das Minimum als
1005 auch das Maximum angenommen werden. Wendet man das Verfahren iterativ an, um
1006 ein $n$-Sortiernetzwerk auf ein ${(n-k)}$-Sortiernetzwerk zu reduzieren,
1007 ergeben sich insgesamt
1008 \begin{equation}\label{eqn:anzahl_schnittmuster}
1009   \prod_{i=n}^{1+n-k} 2i = 2^k \cdot \frac{n!}{(n-k)!}
1010   \quad (n > m)
1011 \end{equation}
1012 \emph{mögliche} Schnittmuster. Diese Schnittmuster sind nicht alle
1013 unterschiedlich. Legt man beispielsweise das Minimum auf die unterste Leitung
1014 und das Maximum auf die oberste Leitung eines Standard-Sortiernetzwerks,
1015 führen beide Reihenfolgen zum selben Ergebnis.
1016
1017 \textit{Moritz Mühlenthaler} zeigt in seiner Arbeit~\cite{M2009}, dass es
1018 möglich ist, mehrere Eingänge gleichzeitig mit Minimum beziehungsweise Maximum
1019 vorzubelegen, ohne die Menge der erreichbaren Sortiernetzwerke einzuschränken.
1020 Dadurch wird die Anzahl der möglichen Schnittmuster reduziert, die Menge der
1021 so erzeugbaren Sortiernetzwerke bleibt aber unverändert. Die Anzahl der
1022 möglichen Schnittmuster setzt sich zusammen aus der Anzahl von Möglichkeiten,
1023 $k$~Leitungen aus $n$~Leitungen auszuwählen, und die möglichen Minimum-~/
1024 Maximum-Muster. Damit ergibt sich folgende Formel für die Anzahl der möglichen
1025 Schnittmuster:
1026 \begin{displaymath}
1027   2^k \cdot \left( \begin{array}{c} n \\ k \end{array} \right)
1028   = 2^{k} \cdot \frac{n!}{k! (n-k)!}
1029   = 2^{k} \cdot \frac{n!}{(n-k)!} \cdot \frac{1}{k!}
1030   \quad (1 \leqq k < n)
1031 \end{displaymath}
1032
1033 Die Anzahl der möglichen Schnittmuster wird mit der Anzahl der zu entfernenden
1034 Leitungen sehr schnell sehr groß. Um ein Sortiernetzwerk mit 32~Eingängen auf
1035 ein Sortiernetzwerk mit 16~Eingängen zu reduzieren, ist ein Schmittmuster mit
1036 16~Schnitten notwendig, für das es bereits etwa ${3,939 \cdot 10^{13}}$
1037 Möglichkeiten gibt. Ein Ausprobieren aller Möglichkeiten ist für große
1038 Netzwerke nicht oder nur unter erheblichem Ressourcenaufwand möglich.
1039
1040 Die Anzahl der \emph{unterschiedlichen} Schnittmuster ist allerdings kleiner
1041 als die Anzahl der möglichen Schnittmuster. Für jeden Komparator auf der
1042 ersten Stufe gibt es neun verschiedene Eingangskonfigurationen: Für beide
1043 Eingänge gibt es drei mögliche Eingangswerte, Minimum, Maximum und
1044 unspezifiziert. Es gibt drei Konfigurationen, bei denen an beiden Eingängen
1045 der gleiche Wert angelegt wird, und sechs Konfigurationen, bei denen sich die
1046 Werte unterscheiden.
1047
1048 Bei diesen letzten sechs Konfigurationen werden je zwei auf das selbe
1049 Ausgangmuster abgebildet, weil die Position des Minimums beziehungsweise des
1050 Maximums durch den Komparator vorgegeben wird. Das heißt, dass die neun
1051 unterschiedlichen Eingangsmuster nur sechs unterschiedliche Ausgangsmuster
1052 erzeugen. In der zweiten und allen folgenden Schichten kann man diesen
1053 Unterschied nicht mehr erkennen. In allen sechs Fällen, in denen sich die
1054 Eingänge unterscheiden, wird anschließend der Komparator entfernt, so dass
1055 sich die Resultate auch in der ersten Schicht nicht unterscheiden.
1056
1057 \begin{figure}
1058   \begin{center}
1059     \includegraphics[viewport=0 0 425 262,width=15cm]{images/count-cuts-16.pdf}
1060   \end{center}
1061   \caption{Anzahl der \emph{unterschiedlichen} Sortiernetzwerke, die durch
1062   8-Schnittmuster aus $\operatorname{OES}(16)$, $\operatorname{BS}(16)$ und
1063   $\operatorname{PS}(16)$ hervorgegangen sind. Die Anzahl der
1064   unterschiedlichen Netzwerke nach $10^6$~Iterationen ist 3519 für das
1065   \emph{Odd-Even-Mergesort}-Netzwerk, 4973 für das \emph{bitone
1066   Mergesort}-Netzwerk und 18764 für das \emph{Pairwise-Sorting}-Netzwerk.}
1067   \label{fig:count-cuts-16}
1068 \end{figure}
1069
1070 Alleine durch Betrachten der ersten Schicht von Komparatoren konnte die Anzahl
1071 der \emph{unterschiedlichen} Schnittmuster auf höchstens $\frac{2}{3}$ der
1072 \emph{möglichen} Schnittmuster reduziert werden. Um die Anzahl der
1073 \emph{unterschiedlichen} Schnittmuster experimentell zu ermitteln, wurden je
1074 eine Million zufällige 8-Schnittmuster auf die 16-Sortiernetzwerke \oes{16},
1075 \bs{16} und \ps{16} angewandt. Anschließend wurde mithilfe einer Hashtabelle
1076 überprüft, ob das resultierende Sortiernetzwerk schon von einem
1077 \emph{äquivalenten} Schnittmuster erzeugt wurde. Falls das Sortiernetzwerk
1078 noch nicht in der Hashtabelle enthalten war, wurde der Zähler für
1079 unterschiedliche Schnittmuster erhöht und das Sortiernetzwerk eingefügt.
1080
1081 Abbildung~\ref{fig:count-cuts-16} trägt die Anzahl der
1082 \emph{unterschiedlichen} Schnittmuster gegen die Anzahl der zufälligen
1083 Schnittmuster auf. Klar zu sehen ist, dass sich die Anzahl der erzeugten
1084 Sortiernetzwerke nach $500.000$~Iterationen nur noch gering verändert und der
1085 Wert nach $1.000.000$~Iterationen allem Anschein nach dem Endwert schon sehr
1086 nahe ist.
1087
1088 Die Anzahl der möglichen 8-Schnittmuster ist entsprechend der
1089 Formel~\eqref{eqn:anzahl_schnittmuster} 3.294.720. Diese möglichen
1090 Schnittmuster führen aber nur zu wenigen \emph{unterschiedlichen}
1091 Sortiernetzwerken: 3519 ($\approx 0,1\%$) im Fall des
1092 \emph{Odd-Even-Mergesort}-Netzwerks, 4973 ($\approx 0,15\%$) beim
1093 \emph{bitonen Mergesort}-Netzwerk und 18764 ($\approx 0,57\%$) beim
1094 \emph{Pairwise-Sorting}-Netzwerk. Zwar ist es möglich, dass mehr Iterationen
1095 die Anzahl der unterschiedlichen Schnittmuster noch wachsen lässt. Die Graphen
1096 in Abbildung~\ref{fig:count-cuts-16} geben jedoch Grund zu der Annahme, dass
1097 die Anzahl dieser zusätzlichen, unterschiedlichen Schnittmuster
1098 vernachlässigbar klein ist.
1099
1100 Bedingt durch die sehr große Anzahl möglicher Schnittmuster ist dieses
1101 Experiment für größere Sortiernetzwerke leider nicht sinnvoll durchführbar.
1102 Die Hashtabelle würde mehr Arbeitsspeicher benötigen als in derzeitigen
1103 Rechnern vorhanden ist, bevor ein entsprechender Graph den linearen Bereich
1104 für „kleine“ x-Werte verlässt.
1105
1106 Um die Anzahl der unterschiedlichen Schnittmuster trotzdem abschätzen zu
1107 können, kann man sich einer stochastischen Methode bedienen, der sogenannten
1108 \emph{Monte-Carlo-Methode}, die \textit{Rolf Wanka} in~\cite{W2006} für
1109 schwierige Zählprobleme vorstellt. Zunächst generiert man eine Menge~$S$ von
1110 $k$~unterschiedlichen Schnittmustern. Anschließend werden $n$~Schnittmuster
1111 zufällig erzeugt und überprüft, ob sie in der Menge~$S$ enthalten sind. Unter
1112 der Annahme, dass das Verhältnis der zufälligen Schnittmuster, die in $S$
1113 enthalten sind, und $n$ dem Verhältnis von $k$ und der Anzahl der
1114 unterschiedlichen Schnittmuster ingesamt entspricht, kann man die Anzahl der
1115 unterschiedlichen Schnittmuster abschätzen.
1116
1117 \begin{figure}
1118   \begin{center}
1119     \includegraphics[viewport=0 0 425 262,width=15cm]{images/collisions-10000-1000000-32.pdf}
1120   \end{center}
1121   \caption{Abschnätzung der unterschiedlichen Schnittmuster mit der
1122   \emph{Monte-Carlo-Methode} für $\operatorname{OES}(32)$ und
1123   $\operatorname{BS}(32)$.}
1124   \label{fig:collisions-10000-1000000-32}
1125 \end{figure}
1126
1127 In Abbildung~\ref{fig:collisions-10000-1000000-32} ist das Ergebnis des
1128 Monte-Carlo-Algorithmus für 16-Schnittmuster zu sehen, die auf
1129 $\operatorname{OES}(32)$ und $\operatorname{BS}(32)$ angewandt wurden: Von
1130 jedem Sortiernetzwerk wurden zunächst eine Menge~$S$ von 10.000
1131 \emph{unterschiedlichen} Schnittmustern erzeugt. Anschließend wurden 1.000.000
1132 zufällige Schnittmuster erzeugt und der Anteil der zufälligen Schnittmuster,
1133 die \emph{äquivalent} zu einem in~$S$ enthalten Schnittmuster sind, berechnet.
1134 Für $\operatorname{OES}(32)$ war dieser Anteil etwa $0,19 \%$, für
1135 $\operatorname{BS}(32)$ etwa $0,29 \%$. Das ergibt eine Abschätzung von $5,2
1136 \cdot 10^6$ unterschiedlichen 16-Schnittmustern für $\operatorname{OES}(32)$
1137 und $3,4 \cdot 10^6$ für $\operatorname{BS}(32)$.
1138
1139 \begin{figure}
1140   \begin{center}
1141     \includegraphics[viewport=0 0 425 262,width=15cm]{images/collisions-100000-1000000-32-ps.pdf}
1142   \end{center}
1143   \caption{Abschnätzung der unterschiedlichen Schnittmuster mit der
1144   \emph{Monte-Carlo-Methode} für $\operatorname{PS}(32)$. 385 von 1.000.000
1145   zufälligen Schnittmustern waren äquivalent zu einem Schnittmuster in einer
1146   Menge von 100.000. Daraus ergibt sich eine Schätzung von $2,6 \cdot 10^8$
1147   unterschiedlichen Schnittmustern.}
1148   \label{fig:collisions-100000-1000000-32-ps}
1149 \end{figure}
1150
1151 Im vorherigen Abschnitt wurde das \emph{Pairwise-Sorting-Netzwerk}
1152 $\operatorname{PS}(32)$ nicht betrachtet, da es für dieses Netzwerk viel mehr
1153 unterschiedliche 16-Schnittmuster gibt als für $\operatorname{OES}(32)$ und
1154 $\operatorname{BS}(32)$. In Anbetracht der Tatsache, dass die Anzahl der
1155 unterschiedlichen 8-Schnittmuster für $\operatorname{PS}(16)$ in
1156 Abbildung~\ref{fig:count-cuts-16} bereits mehr als dreimal größer war als die
1157 Anzahl für $\operatorname{OES}(16)$ beziehungsweise $\operatorname{BS}(16)$,
1158 ist dieser Umstand wenig verwunderlich. Entsprechend hätte man in einem
1159 kombinierten Graphen keine Details mehr erkennen können. Aufgrund der hohen
1160 Anzahl unterschiedlicher Schnittmuster, wurde für das gleiche Experiment mit
1161 $\operatorname{PS}(32)$ eine initiale Menge von 100.000 unterschiedilchen
1162 Schnittmustern erzeugt. Trotzdem wurden nach 1.000.000 Iterationen nur 385
1163 Schnittmuster gefunden, die zu einem Schnittmuster in der Menge äquivalent
1164 sind. Daraus ergibt sich eine Abschätzung von $2,6 \cdot 10^8$
1165 unterschiedlichen Schnittmustern -- zwei Zehnerpotenzen mehr als bei den
1166 vorherigen Sortiernetzwerken, aber immernoch fünf Zehnerpotenzen kleiner als
1167 die Anzahl der \emph{möglichen} Schnittmuster.
1168
1169 \newpage
1170 \section{Der \textsc{SN-Evolution}-Algorithmus}
1171 \label{sect:sn-evolution}
1172
1173 Der \textsc{SN-Evolution}-Algorithmus ist ein \emph{evolutionärer
1174 Algorithmus}, der die in den vorherigen Abschnitten beschriebenen Mischer
1175 (Abschnitt~\ref{sect:konstruktive_netzwerke}) und Schnittmuster
1176 (Abschnitt~\ref{sect:leitungen_entfernen}) verwendet, um „möglichst gute“
1177 Sortiernetzwerke zu erzeugen. Was ein „gutes“ Sortiernetzwerk ausmacht, wird
1178 in Abschnitt~\ref{sect:bewertung} behandelt.
1179
1180 \subsection{Bewertungsfunktion}\label{sect:bewertung}
1181
1182 Um Sortiernetzwerke überhaupt optimieren zu können, muss zunächst die
1183 {\em Güte} eines Netzwerkes definiert werden. Prinzipiell gibt es zwei Ziele,
1184 die bei Sortiernetzwerken verfolgt werden können:
1185 \begin{itemize}
1186   \item Möglichst wenige Komparatoren („effizient“)
1187   \item Möglichst wenige Schichten („schnell“)
1188 \end{itemize}
1189
1190 Diese Ziele führen im Allgemeinen zu unterschiedlichen Netzwerken. Das
1191 effizienteste bekannte Sortiernetzwerk für 16~Eingänge besteht aus
1192 60~Komparatoren in 10~Schichten. Das schnellste Netzwerk besteht aus
1193 61~Komparatoren in nur 9~Schichten.
1194
1195 Eine Gütefunktion, die die beiden Ziele "`effizient"' und "`schnell"'
1196 berücksichtigen kann, hat die folgende allgemeine Form:
1197 \begin{equation}
1198   \operatorname{Guete}(S) = w_{\mathrm{Basis}}
1199                     + w_{\mathrm{Komparatoren}} \cdot \left|S\right|_\mathrm{Komparatoren}
1200                     + w_{\mathrm{Schichten}} \cdot \left|S\right|_\mathrm{Schichten}
1201 \end{equation}
1202 Die Parameter $w_{\mathrm{Komparatoren}}$ und $w_{\mathrm{Schichten}}$ dienen
1203 dabei der Festlegung des Optimierungsziels. Wenn einer der beiden Parameter
1204 gleich Null ist, wird nur das jeweils andere Ziel verfolgt. Sind beide
1205 Parameter gleich Null, werden alle Netzwerke mit der gleich Güte bewertet --
1206 jegliche Ergebnisse sind dann rein zufälliger Natur.\footnote{Dass dies nicht
1207 so schlecht ist wie man intuitiv vermuten könnte, zeigt der
1208 \textsc{SN-Markov}-Algorithmus in Abschnitt~\ref{sect:markov}.}
1209
1210 Da möglichst effiziente und schnelle Sortiernetzwerke gefunden werden sollen,
1211 ist ein kleiner Wert von $\operatorname{Guete}(S)$ besser als ein großer Wert.
1212 Das heißt, dass das Ziel von \textsc{SN-Evolution} ist,
1213 $\operatorname{Guete}(S)$ zu \emph{minimieren}.
1214
1215 Mit dem Parameter $w_{\mathrm{Basis}}$ kann auf die Selektion Einfluss
1216 genommen werden. Ist er groß, wird der relative Unterschied der Güten
1217 verschiedener Netzwerke kleiner, was die {\em Exploration}, das Absuchen des
1218 gesamten Lösungsraums, begünstigt. Wählt man $w_{\mathrm{Basis}}$ hingegen
1219 klein -- in Abhängigkeit von den anderen beiden Parametern sind auch negative
1220 Werte möglich -- werden die relativen Unterschiede groß. Dadurch wird die {\em
1221 Exploitation}, das Finden (lokaler) Optima, bevorzugt.
1222
1223 Diese Parameter haben einen großen Einfluss auf die Geschwindigkeit, mit der
1224 der \textsc{SN-Evolution}-Algorithmus konvergiert und ob er tatsächlich gute
1225 Lösungen findet oder sich in \emph{lokalen} Optima verrennt. Leider gibt es
1226 kein Patentrezept für die Wahl der Parameter, so dass für verschiedene
1227 Leitungszahlen und Mischer-Typen experimentiert werden muss.
1228
1229 \subsection{Selektion}
1230
1231 Die \emph{Selektion} sorgt dafür, dass bessere Individuen eine größere
1232 Wahrscheinlichkeit haben, zur nächsten Generation beizutragen. Diese
1233 Ungleichbehandlung von Individuen verschiedener Güte ist der Grund für das
1234 Streben des Algorithmus nach besseren Lösungen.
1235
1236 Obwohl dieser Vorteil für gute Individuen intuitiv als sehr gering erscheint,
1237 ist es sehr häufig, dass die \emph{Exploitation} überhand gewinnt und der
1238 Algorithmus vorschnell in Richtung eines lokalen Optimums optimiert.
1239
1240 Die in \textsc{SN-Evolution} implementierte Selektion lässt sich mithilfe von
1241 Pseudocode wie folgt beschreiben:
1242 \begin{verbatim}
1243   Gütesumme := 0
1244   Auswahl := (leer)
1245   
1246   für jedes Individuum in Population
1247   {
1248     reziproke Güte := 1.0 / Guete(Individuum)
1249     Wahrscheinlichkeit P := reziproke Güte / (Gütesumme + reziproke Güte)
1250     Gütesumme := Gütesumme + reziproke Güte
1251   
1252     mit Wahrscheinlichkeit P
1253     {
1254       Auswahl := Individuum
1255     }
1256   }
1257   gib Auswahl zurück
1258 \end{verbatim}
1259
1260 \subsection{Rekombination}
1261
1262 Bei der Rekombination werden zwei Individuen --~hier Sortiernetzwerke~-- zu
1263 einer neuen Lösung kombiniert. Dazu verwenden wir einen Mischer, zum Beispiel
1264 den {\em bitonen Mischer} (Abschnitt~\ref{sect:der_bitone_mischer}) oder den
1265 \emph{Odd-Even}-Mischer (Abschnitt~\ref{sect:der_odd_even_mischer}), um die
1266 beiden Netzwerke zu einem Netzwerk mit $2n$~Leitungen zusammenzufügen.
1267 Anschließend werden zufällig $n$~Leitungen mit einem $n$-Schnittmuster wie in
1268 Abschnitt~\ref{sect:leitungen_entfernen} beschrieben entfernt.
1269
1270 Dieses Verfahren hat den großen Vorteil, dass es die Sortiereigenschaft
1271 erhält. Entsprechend muss nicht aufwendig überprüft werden, ob das
1272 Komparatornetzwerk die Sortiereigenschaft besitzt. Der Nachteil ist, dass
1273 nicht alle Sortiernetzwerke auf diese Art und Weise erzeugt werden können.
1274
1275 \subsection{Mutation}
1276
1277 Zu einem vollständigen evolutionären Algorithmus gehört außerdem die Mutation
1278 --~eine zufällige Veränderung einer Lösung. Leider ist es nicht möglich ein
1279 Sortiernetzwerk zufällig zu verändern und dabei die Sortiereigenschaft zu
1280 erhalten. Selbst das \emph{Hinzufügen} eines zufälligen Komparators kann diese
1281 Eigenschaft zerstören.
1282
1283 Nach einer Mutation müsste man überprüfen, ob das neue Komparatornetzwerk die
1284 Sortiereigenschaft noch besitzt. Nach heutigem Wissenstand ist diese
1285 Überprüfung nur mit exponentiellem Aufwand möglich, etwa durch das
1286 Ausprobieren aller $2^n$~Bitmuster, wie in Abschnitt~\ref{sect:0-1-prinzip}
1287 beschrieben.
1288
1289 Um das Potenzial einer Mutation abzuschätzen wurde in \textsc{SN-Evolution}
1290 eine Überprüfung eingebaut: Unmittelbar vor dem Einfügen in die Population
1291 überprüft eine Funktion die Notwendigkeit jedes einzelnen Komparators. Dazu
1292 wird nacheinander jeder Komparator entfernt und überprüft, ob das verbleibende
1293 Netzwerk die Sortiereigenschaft noch besitzt.
1294
1295 Trotz des hohen Rechenaufwandes -- bei 16-Sortiernetzwerken sind gut
1296 4~Millionen Tests notwendig, um alle Komparatoren zu überprüfen -- waren die
1297 Ergebnisse ernüchternd: Nach circa 1~Million Iterationen mit
1298 16-Sortiernetzwerken fand der so modifizierte Algorithmus keinen einzigen
1299 Komparator, den er hätte entfernen können.
1300
1301 \subsection{Güte}
1302
1303 Die Qualität der erreichten Sortiernetzwerke wurde mit eine Gütefunktion
1304 beurteilt, die entsprechend dem im Abschnitt~\ref{sect:bewertung}
1305 vorgestellten Muster definiert ist. Wie beschrieben müssen die Faktoren häufig
1306 an die aktuelle Problemgröße angepasst werden, damit \textsc{SN-Evolution}
1307 schnell gute Ergebnisse liefert. Als guter Standardansatz haben sich die
1308 folgenden Werte herausgestellt:
1309 \begin{eqnarray*}
1310 w_{\mathrm{Basis}} &=& 0 \\
1311 w_{\mathrm{Komparatoren}} &=& 1 \\
1312 w_{\mathrm{Schichten}} &=& \left|S\right|_\mathrm{Leitungen}
1313 \end{eqnarray*}
1314
1315 \subsection{Versuche mit dem bitonen Mischer}
1316
1317 \begin{figure}
1318   \begin{center}
1319     \input{images/16-e1-bitonic-1296542566.tex}
1320   \end{center}
1321   \caption{Sortiernetzwerk mit 16~Leitungen und 67~Komparatoren in
1322     10~Schichten. Das Netzwerk wurde von dem Algorithmus
1323     \textsc{SN-Evolution} unter Verwendung des \emph{bitonen Mischers}
1324     erzeugt.}
1325   \label{fig:16-e1-bitonic-1296542566}
1326 \end{figure}
1327
1328 Verwendet man den \emph{bitonen Mischer} in der Rekombinationsphase von
1329 \textsc{SN-Evolution}, so erhält man Netzwerke wie das in
1330 Abbildung~\ref{fig:16-e1-bitonic-1296542566} dargestellte: Der Algorithmus
1331 wurde mit dem \emph{Odd-Even-Transpositionsort}-Netzwerk als triviale
1332 Initiallösung gestartet. Das Ergebnis ist ein Netzwerk, das effizienter ist
1333 als das bitone Mergesort-Netzwerk: $\operatorname{BS}(16)$ benötigt
1334 80~Komparatoren, das Sortiernetzwerk in
1335 Abbildung~\ref{fig:16-e1-bitonic-1296542566} benötigt lediglich~67.
1336
1337 \subsection{Versuche mit dem \emph{Odd-Even}-Mischer}
1338
1339 \begin{figure}
1340   \begin{center}
1341     \input{images/16-e1-oddeven-1296543330.tex}
1342   \end{center}
1343   \caption{Sortiernetzwerk mit 16~Leitungen und 63~Komparatoren in
1344     10~Schichten. Das Netzwerk wurde von dem Algorithmus
1345     \textsc{SN-Evolution} unter Verwendung des \emph{Odd-Even}-Mischers
1346     erzeugt.}
1347   \label{fig:16-e1-oddeven-1296543330}
1348 \end{figure}
1349
1350 Leider lies sich das Ergebnis des bitonen Mischers -- das von
1351 \textsc{SN-Evolution} ausgegebene Netzwerk war effizienter als das rekursiv
1352 aus dem verwendeten Mischer aufgebaute Sortiernetzwerk -- mit dem
1353 \emph{Odd-Even}-Mischer nicht wiederholen. Zwar erreichen die
1354 Sortiernetzwerke, die \textsc{SN-Evolution} unter Verwendung des
1355 \emph{Odd-Even}-Mischers findet, das \emph{Odd-Even-Mergesort}-Netzwerk
1356 bezüglich Schnelligkeit und Effizienz, ein Beispiel hierfür ist in
1357 Abbildung~\ref{fig:16-e1-oddeven-1296543330} zu sehen. Ein Netzwerk, das
1358 $\operatorname{OES}(n)$ in mindestens einem Merkmal übertrifft, konnte jedoch
1359 nicht beobachtet werden.
1360
1361 \todo{Ggf. Abschnitt „Shmoo-Äquivalenz“ kürzen und hier einbauen.}
1362
1363 %\begin{figure}
1364 %\begin{center}
1365 %\input{images/08-e2-1237993371.tex}
1366 %\end{center}
1367 %\caption{{\tt images/08-e2-1237993371.tex}: 19~Komparatoren in 6~Schichten}
1368 %\label{fig:08-e2-1237993371}
1369 %\end{figure}
1370 %
1371 %\begin{figure}
1372 %\begin{center}
1373 %\input{images/09-e2-1237997073.tex}
1374 %\end{center}
1375 %\caption{{\tt images/09-e2-1237997073.tex}: 25~Komparatoren in 8~Schichten}
1376 %\label{fig:09-e2-1237997073}
1377 %\end{figure}
1378 %
1379 %\begin{figure}
1380 %\begin{center}
1381 %\input{images/09-e2-1237999719.tex}
1382 %\end{center}
1383 %\caption{{\tt images/09-e2-1237999719.tex}: 25~Komparatoren in 7~Schichten}
1384 %\label{fig:09-e2-1237999719}
1385 %\end{figure}
1386 %
1387 %\begin{figure}
1388 %\begin{center}
1389 %\input{images/10-e2-1239014566.tex}
1390 %\end{center}
1391 %\caption{{\tt images/10-e2-1239014566.tex}: 29~Komparatoren in 8~Schichten}
1392 %\label{fig:10-e2-1239014566}
1393 %\end{figure}
1394
1395 %\input{shmoo-aequivalenz.tex}
1396
1397 \newpage
1398 \section{Der \textsc{SN-Evolution-Cut}-Algorithmus}
1399 \label{sect:sn-evolution-cut}
1400
1401 Das Programm \textsc{SN-Evolution-Cut} implementiert einen evolutionären
1402 Algorithmus, der zu einem gegebenen Sortiernetzwerk und einer gewünschten
1403 Leitungszahl ein Schnittmuster sucht, dass ein Sortiernetzwerk mit einer
1404 möglichst geringen Anzahl von Komparatoren und Schichten ergibt. Zur Bewertung
1405 von Sortiernetzwerken siehe auch Abschnitt~\ref{sect:bewertung}. Mit diesem
1406 Algorithmus wurden zu einer Reihe von „interessanten“ Netzwerken möglichst
1407 gute Schnittmuster gesucht.
1408
1409 Der \textsc{SN-Evolution-Cut}-Algorithmus verwendet \emph{Schnittmuster}, die
1410 in Abschnitt~\ref{sect:anzahl_schnittmuster} definiert wurden, als Individuen.
1411 Um zwei Individuen zu rekombinieren werden die ersten $r$~Schnitte des einen
1412 Schnittmusters verwendet und die letzten ${c-r}$~Schnitte des zweiten
1413 Schmittmusters. $r$ ist eine Zufallsvariable mit $0 \leqq r \leqq c$.
1414
1415 Die Mutation setzt entweder die Leitungs-Nummer eines Schnitts~$i$ zufällig
1416 auf einen neuen Wert $l$ mit $0 \leqq l \le n-i$ oder invertiert die
1417 Schnitt-Richtung.
1418
1419 \subsection{Versuche mit dem bitonen Mergesort-Netzwerk}
1420
1421 In \cite{MW2010} zeigen \textit{Moritz Mühlenthaler} und \textit{Rolf Wanka},
1422 wie man einen bitonen Mischer, der nach Batchers Methode konstruiert wurde,
1423 durch systematisches Entfernen von Leitungen in einen ebenfalls bitonen
1424 Mischer mit der Hälfte der Leitungen transformiert. Diese alternativen Mischer
1425 sparen im Vergleich zu den Mischern, die nach Batchers Methode konstruiert
1426 werden, Komparatoren ein.
1427
1428 Beispielsweise geben \textit{Mühlenthaler} und \textit{Wanka} ein
1429 Sortiernetzwerk mit 16~Eingängen an, das mithilfe der alternativen Mischer
1430 konstruiert wurde. Dieses Sortiernetzwerk benötigt 68~Komparatoren, 12~weniger
1431 als das bitone Mergesort-Netzwerk nach Batchers Methode. Gegenüber Batchers
1432 Methode sparen so konstruierte Sortiernetzwerke ${\frac{1}{4}n(\log n - 1)}$
1433 Komparatoren ein.
1434
1435 \begin{figure}
1436   \begin{center}
1437     \input{images/16-ec-from-bs32.tex}
1438   \end{center}
1439   \caption{Sortiernetzwerk mit 16~Leitungen und 68~Komparatoren in
1440     10~Schichten. Das Netzwerk wurde von dem Algorithmus
1441     \textsc{SN-Evolution-Cut} aus dem \emph{bitonen Mergesort-Netzwerk}
1442     $\operatorname{BS}(32)$ durch 16~Schnitte erzeugt.}
1443   \label{fig:16-ec-from-bs32}
1444 \end{figure}
1445
1446 \begin{figure}
1447   \begin{center}
1448     \input{images/16-ec-from-bs32-normalized.tex}
1449   \end{center}
1450   \caption{Sortiernetzwerk mit 16~Leitungen und 68~Komparatoren in
1451     10~Schichten. Das Netzwerk wurde von dem Algorithmus
1452     \textsc{SN-Evolution-Cut} aus dem bitonen Mergesort-Netzwerk
1453     $\operatorname{BS}(32)$ durch 16~Schnitte erzeugt.}
1454   \label{fig:16-ec-from-bs32-normalized}
1455 \end{figure}
1456
1457 Startet man {\sc SN-Evolution-Cut} mit dem bitonen Mergesort-Netzwerk
1458 $\operatorname{BS}(32)$ und der Vorgabe 16~Leitungen zu entfernen, liefert der
1459 Algorithmus Sortiernetzwerke, die ebenfalls aus 68~Komparatoren bestehen. Ein
1460 16-Sortiernetzwerk, das auf diese Weise generiert wurde, ist in den
1461 Abbildungen~\ref{fig:16-ec-from-bs32} und~\ref{fig:16-ec-from-bs32-normalized}
1462 zu sehen. Abbildung~\ref{fig:16-ec-from-bs32} zeigt $\operatorname{BS}(32)$
1463 und das
1464 ${\operatorname{MIN}(0,5,9,11,15,17,20,22,26,29,30)}$-${\operatorname{MAX}(2,4,13,19,24)}$-Schnittmuster,
1465 das durch \textsc{SN-Evolution-Cut} gefunden wurde.
1466 Abbildung~\ref{fig:16-ec-from-bs32-normalized} zeigt das 16-Sortiernetzwerk
1467 nachdem das Schnittmuster angewandt und das Netzwerk normalisiert wurde. Eine
1468 Ähnlichkeit zu $\operatorname{BS}(32)$ oder $\operatorname{BS}(16)$ ist in
1469 diesem Netzwerk nicht mehr erkennbar -- insbesondere die ersten Schichten des
1470 Netzwerks scheinen rein zufällig zu sein.
1471
1472 \begin{figure}
1473   % 0:MAX 1:MAX 4:MIN 6:MAX 9:MAX 11:MAX 14:MIN 15:MAX 18:MAX 19:MAX 21:MAX
1474   % 23:MIN 24:MAX 25:MAX 30:MIN 31:MIN 32:MAX 34:MAX 36:MIN 37:MAX 40:MAX
1475   % 43:MAX 46:MIN 47:MAX 48:MAX 49:MAX 54:MIN 55:MAX 56:MAX 58:MIN 60:MAX
1476   % 63:MAX
1477   \begin{center}
1478     \input{images/32-ec-from-bs64.tex}
1479   \end{center}
1480   \caption{Sortiernetzwerk mit 32~Leitungen und 206~Komparatoren in
1481     15~Schichten. Das Netzwerk wurde von dem Algorithmus
1482     \textsc{SN-Evolution-Cut} aus dem bitonen Mergesort-Netzwerk
1483     $\operatorname{BS}(64)$ durch 32~Schnitte erzeugt. Das zugehörige
1484     Schnittmuster ist
1485     $\operatorname{MIN}(4, 14, 23, 30, 31, 36, 46, 54, 58)$,
1486     $\operatorname{MAX}(0, 1, 6, 9, 11, 15, 18, 19, 21, 24, 25, 32, 34, 37,
1487     40, 43, 47, 48, 49, 55, 56, 60, 63)$.}
1488   \label{fig:32-ec-from-bs64}
1489 \end{figure}
1490
1491 Das Ergebnis von \textit{Mühlenthaler} und \textit{Wanka}, die den bitonen
1492 Mischer optimiert und anschließend aus diesen Mischern ein Sortiernetzwerk
1493 konstruiert haben, kann demnach auch erreicht werden, wenn
1494 $\operatorname{BS}(32)$ auf ein 16-Sortiernetzwerk reduziert wird. Bei anderen
1495 Größen, beispielsweise wenn man $\operatorname{BS}(64)$ auf ein
1496 32-Sortiernetzwerk reduziert, kann das Ergebnis sogar noch übertroffen werden,
1497 wie in Abbildung~\ref{fig:32-ec-from-bs64} zu sehen: Ein nach Batchers Methode
1498 konstruiertes Sortiernetzwerk benötigt 240~Komparatoren, ein aus den
1499 optimierten Mischern aufgebautes Netzwerk verbessert die Kosten auf
1500 208~Komparatoren. Das in Abbildung~\ref{fig:32-ec-from-bs64} dargestellte
1501 Sortiernetzwerk benötigt lediglich 206~Komparatoren. Die Komparatoren aller
1502 dieser Netzwerke können in 15~Schichten angeordnet werden, so dass die
1503 Verzögerung dieser Sortiernetzwerke gleich ist.
1504
1505 Leider sind die Schnittmuster, die \textsc{SN-Evolution-Cut} ausgibt, sehr
1506 unregelmäßig. Bisher ist es nicht gelungen eine Konstruktionsanweisung für
1507 gute Schnittmuster anzugeben.
1508
1509 Entscheidend für das Ergebnis eines Schnittmusters scheint beim bitonen
1510 Mergesort-Netzwerk die Aufteilung der Minimum- und Maximumschnitte zu sein.
1511 Von Hundert 16-Schnittmustern für $\operatorname{BS}(32)$, die in
1512 Sortiernetzwerken mit 68~Komparatoren in 10~Schichten resultieren, hatten 73
1513 ein Verhältnis von $5/11$, 13 hatten ein Verhältnis von $4/12$ und 14 hatten
1514 ein Verhältnis von $3/13$ Minimum- beziehungsweise Maximumschnitten. Da sich
1515 die Schnittmuster aufgrund der Symmetrie des bitonen Mergesort-Netzwerks
1516 leicht invertieren lassen, werden der Fall, dass es mehr Minimumschnitte, und
1517 der Fall, dass es mehr Maximumschnitte gibt, nicht unterschieden.
1518
1519 Dass die Ergebnisse von \textsc{SN-Evolution-Cut} keine erkennbare Struktur
1520 haben, ist jedoch kein Eigenschaft des Algorithmus, sondern hängt insbesondere
1521 von der Eingabe ab. Wird \textsc{SN-Evolution-Cut} beispielsweise mit dem
1522 \emph{Odd-Even-Transpositionsort-Netzwerk} $\operatorname{OET}(n)$ und
1523 $m$~Schnitten gestartet, so ist das beste Ergebnis immer das
1524 $\operatorname{OET}(n-m)$-Netzwerk. 
1525
1526 \begin{figure}
1527   \begin{center}
1528     \input{images/16-ec-from-ps32.tex}
1529   \end{center}
1530   \caption{Sortiernetzwerk mit 16~Leitungen und 63~Komparatoren in
1531     10~Schichten. Das Netzwerk wurde von dem Algorithmus
1532     \textsc{SN-Evolution-Cut} aus dem \emph{Pairwise-Sorting-Netzwerk}
1533     $\operatorname{PS}(32)$ durch 16~Schnitte erzeugt.}
1534   \label{fig:16-ec-from-ps32}
1535 \end{figure}
1536
1537 \subsection{Versuche mit dem Pairwise-Sorting-Netzwerk}
1538
1539 Anders verhält sich das \emph{Pairwise-Sorting-Netzwerk}
1540 $\operatorname{PS}(n)$, das \textit{Ian Parberry} in seiner Arbeit „The
1541 Pairwise Sorting Network“ \cite{P1992} definiert. Startet man
1542 \textsc{SN-Evolution-Cut} mit $\operatorname{PS}(32)$ und der Vorgabe,
1543 16~Leitungen zu entfernen, erhält man ein Sortiernetzwerk, dass die gleiche
1544 Anzahl an Komparatoren und Schichten hat wie $\operatorname{PS}(16)$ und
1545 $\operatorname{OES}(16)$. Eines dieser Sortiernetzwerke ist in
1546 Abbildung~\ref{fig:16-ec-from-ps32} dargestellt.
1547
1548 Obwohl das \emph{Pairwise-Sorting-Netzwerk} den \emph{Odd-Even}-Mischer nicht
1549 einsetzt und auch nicht auf einem Mischer basiert, ist der
1550 $\operatorname{OEM}(8,8)$ im Sortiernetzwerk in
1551 Abbildung~\ref{fig:16-ec-from-ps32} eindeutig erkennbar (Schichten~7--10). In
1552 den Schichten~1--6 erkennt man zwei unabhängige Sortiernetzerke, die
1553 strukturell identisch zu $\operatorname{PS}(8)$ sind -- lediglich die
1554 Schichten~1 und~2 sowie 4~und~5 sind vertauscht.
1555
1556 \begin{figure}
1557   \begin{center}
1558     \input{images/32-pairwise-cut-16-pairwise.tex}
1559   \end{center}
1560   \caption{PS(32) mit 16 Schnitten zu PS(16).}
1561   \label{fig:ps16-from-ps32}
1562 \end{figure}
1563
1564 Für das \emph{Pairwise-Sorting-Netzwerk} ist es vergleichsweise einfach
1565 regelmäßige Schnittmuster anzugeben, die aus dem Netzwerk einen kleineres
1566 schnelles und effizientes Sortiernetzwerk erzeugen. Beispielsweise führt das
1567 einfache Schnittmuster
1568 \begin{displaymath}
1569 \textit{Eingang}_i = \left\{ \begin{array}{rl}
1570   -\infty & \quad \textrm{falls } i < \frac{1}{4} n \\
1571    \infty & \quad \textrm{falls } i \geqq \frac{3}{4} n \\
1572         ? & \quad \mathrm{sonst}
1573   \end{array} \right.
1574 \end{displaymath}
1575 für $\operatorname{PS}\left(n = 2^d\right)$ zum Sortiernetzwerk
1576 $\operatorname{PS}\left(\frac{1}{2}n\right)$. Die Art und Weise, mit der
1577 dieses Schnittmuster Komparatoren eliminiert und welche Komparatoren das
1578 verbleibende Netzwerk ausmachen, ist in Abbildung~\ref{fig:ps16-from-ps32}
1579 dargestellt. Die matt blauen und roten Leitungen und Komparatoren sind
1580 diejenigen, die Aufgrund eines Minimums oder eines Maximums im resultierenden
1581 Netzwerk nicht mehr enthalten sind. Da die Minima und Maxima bereits auf den
1582 „richtigen“ Leitungen angelegt werden, müssen keine Leitungen vertauscht
1583 werden und das Ergebnis ist bereits normalisiert. Daher ist das resultierende
1584 Netzwerk in schwarz gut zu erkennen.
1585
1586 \begin{figure}
1587   \begin{center}
1588     \input{images/16-pairwise.tex}
1589   \end{center}
1590   \caption{Das $\operatorname{PS}(16)$-Sortiernetzwerk mit 8~Schnitten
1591   ($\operatorname{MIN}(0,2,4,6), \operatorname{MAX}(9,11,13,15)$). Das
1592   resultierende 8-Sortiernetzwerk ist $\operatorname{OES}(8)$.}
1593   \label{fig:16-pairwise}
1594 \end{figure}
1595
1596 Ein Spezialfall ergibt sich, wenn man \textsc{SN-Evolution-Cut} auf
1597 $\operatorname{PS}(16)$ anwendet: In diesem Fall kann man durch ein
1598 8-Schnittmuster das \emph{Odd-Even-Mergesort}-Netzwerk \oes{8} erhalten. Für
1599 größere Sortiernetzwerke ist dies hingegen nicht mehr möglich, beispielsweise
1600 kann $\operatorname{PS}(32)$ nicht durch ein 16-Schnittmuster in \oes{16}
1601 konvertiert werden. Die Verwandschaft von $\operatorname{PS}(n)$ und \oes{n}
1602 untersucht \textit{Moritz Mühlenthaler} ausführlich in~\cite{M2009}.
1603
1604 \subsection{Versuche mit dem Odd-Even-Mergesort-Netzwerk}
1605
1606 In Abschnitt~\ref{sect:anzahl_schnittmuster} wurde bereits untersucht, wie
1607 viele \emph{unterschiedliche} Schnittmuster die konstruktiven Sortiernetzwerke
1608 $\operatorname{OES}(32)$, $\operatorname{BS}(32)$ und $\operatorname{PS}(32)$
1609 besitzen. Eines der Ergebnisse war, dass von diesen Sortiernetzwerken das
1610 \emph{Odd-Even-Mergesort}-Netzwerk die wenigsten unterschiedlichen
1611 16-Schnittmuster besitzt -- nur etwa $5,2$~Millionen. Entsprechend ist es
1612 wenig verwunderlich, dass \textsc{SN-Evolution-Cut} gestartet mit
1613 $\operatorname{OES}(32)$ sehr schnell ein gutes 16-Schnittmuster findet.
1614
1615 Eines der eher zufälligen Schnittmuster ist $\operatorname{MIN}(1, 6, 11, 14,
1616 17, 23, 26, 29)$, $\operatorname{MAX}(2, 7, 8,$ $13, 18, 21, 27, 31)$. Das
1617 Schnittmuster ist in Abbildung~\ref{fig:16-ec-from-oes32-cut} veranschaulicht,
1618 das resultierende Netzwerk ist in Abbildung~\ref{fig:16-ec-from-oes32} zu sehen.
1619
1620 \begin{figure}
1621   \begin{center}
1622     \input{images/16-ec-from-oes32-cut.tex}
1623   \end{center}
1624   \caption{Visualisierung eines 16-Schnittmusters, das auf
1625   $\operatorname{OES}(32)$ angewendet wieder ein schnelles und effizientes
1626   Sortiernetzwerk ergibt.}
1627   \label{fig:16-ec-from-oes32-cut}
1628 \end{figure}
1629
1630 \begin{figure}
1631   \begin{center}
1632     \input{images/16-ec-from-oes32.tex}
1633   \end{center}
1634   \caption{16-Sortiernetzwerk mit 63~Komparatoren in 10~Schichten. 
1635     Das Netzwerk wurde von dem Algorithmus \textsc{SN-Evolution-Cut} aus dem
1636     \emph{Odd-Even-Mergesort-Netzwerk} $\operatorname{OES}(32)$ durch
1637     16~Schnitte erzeugt.}
1638   \label{fig:16-ec-from-oes32}
1639 \end{figure}
1640
1641 \newpage
1642 \section{Der \textsc{SN-Markov}-Algorithmus}
1643 \label{sect:markov}
1644
1645 Der evolutionäre \textsc{SN-Evolution}-Algorithmus aus dem vorherigen
1646 Abschnitt verwendete immer zwei zufällige Sortiernetzwerke („Individuen“) aus
1647 einer Population. Da die beiden „Eltern“ zufällig und unabhängig voneinander
1648 ausgewählt werden, kann es vorkommen, dass das selbe Sortiernetzwerk zweimal
1649 verwendet und mit sich selbst kombiniert wird.
1650
1651 Macht man diesen Spezialfall zum Regelfall, indem man \emph{immer} das
1652 aktuelle Netzwerk mit sich selbst kombiniert und anschließend die Hälfte aller
1653 Leitungen eliminiert, lassen sich einige interessante Beobachtungen anstellen.
1654 Netzwerke, die aus einem Netzwerk $S_0$ durch die beschriebene Kombination von
1655 $S_0$ mit sich selbst und anschließendem Eliminieren der Hälfte der Leitungen
1656 hervorgehen können, heißen \emph{Nachfolger} von $S_0$.
1657
1658 Beim beschriebenen Vorgehen kann man die Sortiernetzwerke als Knoten in einem
1659 (gerichteten) Graphen betrachten. Zwei Knoten $V_0$ und $V_1$, die zwei
1660 Sortiernetzwerke $S_0$ und $S_1$ repräsentieren, sind genau dann mit einer
1661 Kante ${E_{0,1} = (V_0, V_1)}$ verbunden, wenn $S_1$ ein \emph{Nachfolger} von
1662 $S_0$ ist, das heißt dass man $S_1$ durch die Rekombination von $S_0$ mit sich
1663 selbst erzeugen kann.
1664
1665 Wie in Abschnitt~\ref{sect:anzahl_schnittmuster} beschrieben, ist die Anzahl
1666 der \emph{unterschiedlichen} Schnittmuster und damit die Anzahl der Nachfolger
1667 sehr groß. Bei den untersuchten 16-Sortiernetzwerken lag die Anzahl der
1668 Nachfolger zwar noch unter 20.000, bei den untersuchten
1669 32-Sortier\-netz\-werken wurden jedoch bereits bis zu $2,6 \cdot 10^8$
1670 unterschiedliche Schnittmuster geschätzt.
1671
1672 Der Algorithmus {\sc SN-Markov} legt auf diesem Nachfolger-Graph einen
1673 zufälligen Weg (englisch: \textit{random walk}) zurück. Er startet auf einem
1674 gegebenen Sortiernetzwerk. Um von einem Sortiernetzwerk zum Nächsten zu
1675 gelangen, rekombiniert der Algorithmus das aktuelle Sortiernetzwerk mit sich
1676 selbst und erhält so einen zufälligen Nachfolger. In Pseudocode lässt dich der
1677 Algorithmus wie folgt beschreiben:
1678
1679 \begin{verbatim}
1680   Netzwerk := Eingabe
1681   
1682   für n Iterationen
1683   {
1684     Nachfolger := kombiniere (Netzwerk, Netzwerk)
1685     Netzwerk   := Nachfolger
1686   }
1687   
1688   gib Netzwerk zurück
1689 \end{verbatim}
1690
1691 Die Graphen in Abbildung~\ref{fig:markov-comparators} zeigen die Anzahl der
1692 Komparatoren der Sortiernetzwerke, die \textsc{SN-Markov} auf seinem
1693 zufälligen Pfad durchläuft (rot). Für jeden Graphen wurde der
1694 \textsc{SN-Markov}-Algorithmus auf einem entsprechenden
1695 \emph{Odd-Even-Transporitionsort}-Netzwerk gestartet hat mindestens
1696 1.000.000~Iterationen durchlaufen. In jedem Schritt wurde die Anzahl der
1697 Komparatoren des Sortiernetzwerks bestimmt und ein entsprechender Zähler
1698 erhöht. In Abbildung~\ref{fig:markov-comparators} ist die resultierende
1699 prezenturale Verteilung zu sehen.
1700
1701 Ebenfalls in die Graphen in Abbildung~\ref{fig:markov-comparators}
1702 eingezeichnet ist eine \emph{Gamma-Verteilung} (grün), die die gemessenen
1703 Daten gut annähert. Die Gamma-Verteilung verwendet einen Offset~$\delta$, der
1704 um Eins kleiner als die kleinste erreichte Komparatorzahl gewählt wurde.
1705 Beispielsweise war die kleinste erreichte Komparatorzahl bei
1706 16-Sortiernetzwerken~63, entsprechend wurde der Offset $\delta = 63 - 1$
1707 gesetzt und die Gamma-Verteilung $g(x - 62)$ eingezeichnet. Die Parameter $k$
1708 und $\theta$, die eine Gamma-Verteilung charakterisieren, wurden mit einem
1709 Fitting-Algorithmus bestimmt. Der konkrete Offset ist als Parameter~$\delta$
1710 unter den Graphen angegeben.
1711
1712 \begin{figure}
1713   \centering
1714   \subfigure[12 Leitungen, $k = 8,267$, $\theta = 0,962$, $\delta = 40$]{\includegraphics[viewport=0 0 425 262,width=7cm]{images/markov-comparators-12-pct.pdf}}
1715   \subfigure[14 Leitungen, $k = 9,522$, $\theta = 0,867$, $\delta = 52$]{\includegraphics[viewport=0 0 425 262,width=7cm]{images/markov-comparators-14-pct.pdf}}
1716   \subfigure[16 Leitungen, $k = 17,939$, $\theta = 1,091$, $\delta = 62$]{\includegraphics[viewport=0 0 425 262,width=7cm]{images/markov-comparators-16-pct.pdf}}
1717   \subfigure[18 Leitungen, $k = 10,724$, $\theta = 0,766$, $\delta = 81$]{\includegraphics[viewport=0 0 425 262,width=7cm]{images/markov-comparators-18-pct.pdf}}
1718   \caption{Anzahl der Komparatoren von Sortiernetzwerken,
1719   die von {\sc SN-Markov} durchlaufen wurden (rot). Ebenfalls eingezeichnet
1720   ist jeweils eine \emph{Gamma-Verteilung} (grün), die eine gute Näherung der
1721   gemessenen Daten darstellt.}
1722   \label{fig:markov-comparators}
1723 \end{figure}
1724
1725 \begin{figure}
1726   \begin{center}
1727     \includegraphics[viewport=0 0 425 262,width=15cm]{images/comparison-comparators-16.pdf}
1728   \end{center}
1729   \caption{Anzahl der Komparatoren, die 16-Sortiernetzwerke von
1730   \textsc{SN-Markov} und \textsc{SN-Evolution} (mit dem
1731   \emph{Odd-Even}-Mischer und dem \emph{bitonen Mischer}) besaßen.}
1732   \label{fig:comparison-comparators}
1733 \end{figure}
1734
1735 Dass der \textsc{SN-Markov}-Algorithmus nicht schlechter ist als der
1736 \textsc{SN-Evolution}-Algo\-rithmus, ist aus dem Graphen in
1737 Abbildung~\ref{fig:comparison-comparators} ersichtlich. Analog zu dem Versuch
1738 mit \textsc{SN-Markov}, wurde beim \textsc{SN-Evolution}-Algorithmus die
1739 Anzahl der Komparatoren jedes neuen Individuums ermittelt und gespeichert. Als
1740 Startnetzwerk diente bei beiden Algorithmen das
1741 \emph{Odd-Even-Transpositionsort}-Netzwerk \oet{16}. Der Graph zeigt auf der
1742 x-Achse die Anzahl der Komparatoren, auf der y-Achse die Häufigkeit, mit der
1743 ein Sortiernetzwerk mit dieser Komparatorzahl durch die Rekombination erzeugt
1744 wurde. Die Ergebnisse von \textsc{SN-Evolution} unterscheiden außerdem nach
1745 dem verwendeten Mischer-Netzwerk -- \oem{32} beziehungsweise \bm{32}.
1746
1747 Sowohl der \textsc{SN-Markov}-Algorithmus, der das
1748 \emph{Odd-Even-Merge}-Netzwerk verwendet, als auch \textsc{SN-Evolution} mit
1749 \oem{32} erreichen eine Komparatorzahl von~63 und finden Sortiernetzwerke, die
1750 bezüglich Effizienz und Geschwindigkeit identisch zu \oes{16} sind.
1751 Interessanterweise erzeugt \textsc{SN-Markov} derartige Netzwerke häufiger:
1752 Während nur $0,000017 \%$ der Individuen von \textsc{SN-Evolution} mit
1753 63~Komparatoren auskamen, ist die Rate bei \textsc{SN-Markov} mit $0,000335
1754 \%$ rund 20~mal höher.
1755
1756 Erwartunggemäß sind die besten Netzwerke, die \textsc{SN-Evolution} mit dem
1757 \emph{bitonen Mischer} findet, aus 67~Komparatoren aufgebaut. Überraschend ist
1758 jedoch, dass in dieser Konfiguration Sortiernetzwerke auftreten können, die
1759 mehr Komparatoren besitzen als \emph{Odd-Even-Transpositionsort} -- \oet{16}
1760 ist aus 120~Komparatoren aufgebaut, bei dem Lauf, der die Daten für
1761 Abbildung~\ref{fig:comparison-comparators} lieferte, traten auch jeweils ein
1762 Sortiernetzwerk mit 121 und 124~Komparatoren auf. Da Sortiernetzwerke mit so
1763 vielen Komparatoren im Verlauf des Experiments selbst nach über 100~Millionen
1764 Iterationen nicht noch einmal erzeugt wurden, handelt es sich vermutlich um
1765 ein Phänomen, das mit der Initialisierung mit dem
1766 \emph{Odd-Even-Transpositionsort}-Netzwerk zusammenhängt.
1767
1768 %\begin{figure}
1769 %  \begin{center}
1770 %  \includegraphics[viewport=0 0 425 262,width=15cm]{images/markov-comparators-14-pct.pdf}
1771 %  \end{center}
1772 %  \caption{Anzahl der Komparatoren von Sortiernetzwerken (mit 14~Leitungen),
1773 %  die von {\sc SN-Markov} durchlaufen wurden. Grün eingezeichnet ist die
1774 %  \emph{Gamma-Verteilung} $f(x - 52)$ mit $k = 9,522$ und $\theta = 0,867$.}
1775 %  \label{fig:markov-comparators-14}
1776 %\end{figure}
1777 %
1778 %\begin{figure}
1779 %  \begin{center}
1780 %  \includegraphics[viewport=0 0 425 262,width=15cm]{images/markov-comparators-16-pct.pdf}
1781 %  \end{center}
1782 %  \caption{Anzahl der Komparatoren von Sortiernetzwerken (mit 16~Leitungen),
1783 %  die von {\sc SN-Markov} durchlaufen wurden. Grün eingezeichnet ist die
1784 %  \emph{Gamma-Verteilung} $f(x - 62)$ mit $k = 17,939$ und $\theta = 1,091$.}
1785 %  \label{fig:markov-comparators-16}
1786 %\end{figure}
1787 %
1788 %\begin{figure}
1789 %  \begin{center}
1790 %  \includegraphics[viewport=0 0 425 262,width=15cm]{images/markov-comparators-18-pct.pdf}
1791 %  \end{center}
1792 %  \caption{Anzahl der Komparatoren von Sortiernetzwerken (mit 18~Leitungen),
1793 %  die von {\sc SN-Markov} durchlaufen wurden. Grün eingezeichnet ist die
1794 %  \emph{Gamma-Verteilung} $f(x - 81)$ mit $k = 10,724$ und $\theta = 0,766$.}
1795 %  \label{fig:markov-comparators-18}
1796 %\end{figure}
1797
1798 %\begin{figure}
1799 %  \begin{center}
1800 %  \includegraphics[viewport=0 0 425 262,width=15cm]{images/markov-cycles-16.pdf}
1801 %  \end{center}
1802 %  \caption{Zyklen, die beim \textit{Random Walk} des
1803 %  \textsc{SN-Markov}-Algorithmus detektiert wurden. Auf der x-Achse sind die
1804 %  Anzahl der Schritte, die \textsc{SN-Markov} zurückgelegt hat, auf der
1805 %  y-Achse die Längen der gefundenen Zyklen aufgetragen. Das initiale
1806 %  Start-Sortiernetzwerk war $\operatorname{OET}(16)$.}
1807 %  \label{fig:markov-cycles-16}
1808 %\end{figure}
1809
1810
1811 \todo{Schreibe noch etwas zu …}
1812 \begin{itemize}
1813   \item Beste erreichte Netzwerke (gleich zu \emph{OE-Mergesort}).
1814   \item Anzahl der erreichbaren Sortiernetzwerke.
1815   \item Anzahl der Komparatoren und Anzahl der Schichten der durchlaufenen
1816     Netzwerke. (Abbildung~\ref{fig:markov-comparators-16})
1817   \item \textsc{SN-Count-Markov} (ggf)
1818 \end{itemize}
1819
1820 \newpage
1821 \section{Fazit und Ausblick}
1822
1823 \todo{Ausformulieren}
1824 \begin{itemize}
1825 \item Mit \textsc{SN-Evolution} und \oem{n} kann man nicht besser werden als
1826   \oes{n}.
1827 \item Mit \textsc{SN-Evolution} und \bm{n} kann man besser werden als \bs{n}.
1828 \item Vermutlich kann man mit \textsc{SN-Evolution} und \bm{n} so gut werden
1829 wie \textsc{SN-Evolution-Cut}, wenn er mit \bs{2n} gestartet wird.
1830 \item Leider sind keine konstruktiven Methoden erkannt worden.
1831 \end{itemize}
1832
1833 Die Möglichkeiten, die Evolutionäre Algorithmen bei der Optimierung von
1834 Sortiernetzwerken bieten, sind durch die in dieser Arbeit vorgestellten
1835 Herangehensweisen bei weitem nicht erschöpft.
1836
1837 Im Folgenden werden Ansätze umrissen, mit denen an die Untersuchungen in
1838 dieser Arbeit nahtlos angeknöpft werden könnte.
1839
1840 \subsection{Ausblick: Das \textit{Pairwise-Sorting}-Netzwerk und \textsc{SN-Evolution}}
1841
1842 Die aktuelle Implementierung von \textsc{SN-Evolution}
1843 (Abschnitt~\ref{sect:sn-evolution}) kann sowohl den \emph{bitonen Mischer} als
1844 auch den \emph{Odd-Even}-Mischer verwenden, um zwei Individuen zu
1845 rekombinieren. Das \emph{Pairwise-Sorting}-Netzwerk verwendet zwar keinen
1846 Mischer, es ist aber ebenfalls rekursiv über kleinere Versionen von sich
1847 selbst definiert. Das heißt, dass \ps{n} aus zwei Instanzen von
1848 $\ps{\frac{n}{2}}$ und zusätzlichen Komparatoren besteht, die die Eingabe für
1849 die kleineren Sortiernetzwerke vorbereiten und anschließend für eine sortierte
1850 Ausgaben sorgen. Anstelle von $\ps{\frac{n}{2}}$ kann man natürlich beliebige
1851 Sortiernetzwerke mit $\frac{n}{2}$~Leitungen verwenden.
1852
1853 Dies ließe sich für \textsc{SN-Evolution} nutzen, um zwei Individuen zu
1854 rekombinieren. Da es für das \emph{Pairwise-Sorting}-Netzwerk sehr viele
1855 \emph{unterscheidliche} Schnittmuster gibt
1856 (Abbschnitt~\ref{sect:anzahl_schnittmuster}), ist es möglich, dass die
1857 Verwendung dieser Rekombinationsmethode neue Ergebnisse ermöglicht. Leider
1858 wird die Aussicht auf Erfolg durch die Tatsache geschmälert, dass keine
1859 $n$-Schnittmuster für \ps{2n} gefunden werden konnten, die zu besseren
1860 $n$-Sortiernetzwerken als \ps{n} führen.
1861
1862 \subsection{Ausblick: Kooperation von \textsc{SN-Evolution} und \textsc{SN-Evolution-Cut}}
1863
1864 Ähnlich zu der parasitären \emph{Co-Evolution}, die \textit{W.~Daniel Hillis}
1865 in~\cite{H1992} beschreibt, könnte man die Algorithmen \textsc{SN-Evolution}
1866 und \textsc{SN-Evolution-Cut} versuchen zu kombinieren. Nach dem Zusammenfügen
1867 von zwei $n$-Sortiernetzwerken könnte der Algorithmus
1868 \textsc{SN-Evolution-Cut} beispielsweise einen möglichst guten Schnitt für
1869 \emph{dieses} Netzwerk ermitteln. Da sich die Lösungen, die Evolutionäre
1870 Algorithmen in ihre Population aufnehmen, in den ersten Schritten rasch
1871 verbessern, könnten selbst weniger Iterationen von \textsc{SN-Evolution-Cut}
1872 die Zwischenlösungen von \textsc{SN-Evolution} deutlich verbessern.
1873
1874 Alternativ könnte man -- analog zur Herangehensweise von \textit{Hillis} --
1875 eine zweite Population von Schnittmustern evolvieren, die für die
1876 Sortiernetzwerke in der Population von \textsc{SN-Evolution} besonders gut
1877 funktionieren. In jeder Iteration wendet man alle oder eine zufällige Menge
1878 Schnittmuster auf das zusammengeführte Netzwerk an und gibt dem besten
1879 Ergebnis den Zuschlag. Anschließend erfährt das entsprechende Schnittmuster
1880 eine Aufwertung, so dass es wahrscheinlicher wird, dass \emph{dieses}
1881 Schnittmuster zur nächten Generation beiträgt. Im Gegensatz zum Ansatz der
1882 parasitären Eingaben entsteht eine \emph{Synergie} zweier Populationen, die
1883 das Gesamtergebnis oder zumindest die Konvergenzgeschwindigkeit verbessern
1884 könnte.
1885
1886 \newpage
1887 \section{Implementierung}
1888
1889 Alle in dieser Arbeit beschriebenen Versuche wurden mit einer eigens
1890 entwickelten C-Bibliothek, \textit{libsortnetwork}, und zugehörigen
1891 Kommandozeilen-Programmen durchgeführt. Die Bibliothek wurde unter der
1892 \textit{GNU Lesser General Public License} (LGPL) in der Version~2.1
1893 veröffentlicht; die Kommandozeilen-Programme, die in vielen Fällen lediglich
1894 Funktionalität der Bibliothek auf der Kommandozeile zur Verfügung stellen,
1895 stehen unter der \textit{GNU General Public License}, Version~2. Diese
1896 Lizenzen räumen einem Benutzer weitreichende Rechte ein, unter anderem das
1897 Programm beliebig zu verwenden, zu studieren, zu verändern sowie veränderte
1898 und unveränderte Kopien zu veröffentlichen.
1899
1900 Die Programmierschnittstelle (API) der Bibliothek orientiert sich an
1901 Paradigmen der \textit{objektorientierten Programmierung}. Beispielsweise kann
1902 mit der Funktion \texttt{sn\_network\_ create()} ein neues Zustands-Objekt
1903 erzeugt werden, für das mehrere Manipulations-Methoden, zum Beispiel
1904 \texttt{sn\_network\_comparator\_add()}, zur Verfügung stehen. Auf diese Art
1905 und Weise kann die Bibliothek leicht erweitert werden, ohne dass bestehende
1906 Programme angepasst werden müssen.
1907
1908 Die meisten Kommandozeilen-Programmen lesen ein Komparatornetzwerk von der
1909 Standard-Eingabe und schreiben ihr Ergebnis auf die Standard-Ausgabe. Um
1910 Beispielsweise eine \emph{normalisierte} Variante des \emph{bitonen
1911 Mergesort}-Netzwerks \bs{18} zu erzeugen, kann folgendes Kommando verwendet
1912 werden:
1913 \begin{verbatim}
1914   $ sn-bitonicsort 18 | sn-normalize >sn-18
1915 \end{verbatim}
1916 Dieses Prinzip, kleine Programme \emph{eine} Aufgabe erledigen zu lassen und
1917 es einfach zu ermöglichen, Programme zu verketten, ist eines der
1918 Grundprinzipien des UNIX-Be\-triebs\-sys\-tems. Es hat sich in den letzten
1919 Jahrzehnten und beim Verfassen dieser Arbeit als sehr flexibel und mächtig
1920 erwiesen.
1921
1922 Funktionen, die von Kommandozeilen-Programmen zur Verfügung gestellt werden,
1923 sind unter anderem das Erzeugen von Odd-Even-Mergesort-, bitonic Mergesort-
1924 und Pairwise-Sorting-Netzwerken, das Normalisieren von Sortiernetzwerken,
1925 Anwendung von Schnittmustern auf Sortiernetzwerke und Anwendung eines
1926 Komparatornetzwerks auf eine Eingabe-Permutation.
1927
1928 \textit{libsortnetwork} kann unter der Web-Adresse
1929 \url{http://octo.it/libsortnetwork/} unentgeldlich heruntergeladen werden.
1930
1931 \newpage
1932 \bibliography{references}
1933 \bibliographystyle{plain}
1934
1935 %\listoffigures
1936
1937 \end{document}
1938
1939 % vim: set shiftwidth=2 softtabstop=2 tabstop=8 fdm=marker tw=78 :