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