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