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