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