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