

# **Untersuchung der Skalierbarkeit von parallelem Sortieren auf einem Multicore-Prozessor**

Bachelorarbeit

Studiengang: Informatik

Bearbeiter: Leon Zoerner

# Inhaltsverzeichnis

|                                                                |          |
|----------------------------------------------------------------|----------|
| <b>1 Einleitung</b>                                            | <b>2</b> |
| 1.1 Motivation . . . . .                                       | 2        |
| 1.2 Zielsetzung und Forschungsfrage . . . . .                  | 2        |
| <b>2 Theoretische Grundlagen</b>                               | <b>3</b> |
| 2.1 Sortieralgorithmen: Quicksort und Mergesort . . . . .      | 3        |
| 2.2 Grundlagen der Parallelisierung . . . . .                  | 3        |
| 2.3 Thread-Modelle, Overheads und Skalierungsgrenzen . . . . . | 3        |
| <b>3 Methodik und Versuchsaufbau</b>                           | <b>3</b> |
| 3.1 Messumgebung und Hardware . . . . .                        | 3        |
| 3.2 Testaufbau und Implementierungsvarianten . . . . .         | 3        |
| 3.3 Messmethodik . . . . .                                     | 3        |
| <b>4 Ergebnisse und Analyse</b>                                | <b>3</b> |
| 4.1 Laufzeitmessungen . . . . .                                | 3        |
| 4.2 Einfluss der Variablen . . . . .                           | 3        |
| 4.3 Bewertung der Parallelisierungseffizienz . . . . .         | 3        |
| 4.4 Grenzen und Fehlerbetrachtung . . . . .                    | 3        |
| <b>5 Diskussion und Fazit</b>                                  | <b>3</b> |
| 5.1 Interpretation der Ergebnisse . . . . .                    | 3        |
| 5.2 Beantwortung der Forschungsfrage . . . . .                 | 3        |
| 5.3 Zusammenfassung . . . . .                                  | 3        |
| <b>6 Anhang</b>                                                | <b>3</b> |
| 6.1 Code . . . . .                                             | 3        |
| 6.2 Exakte Hardware-Spezifikationen . . . . .                  | 3        |

# 1 Einleitung

## 1.1 Motivation

Ziel dieser Arbeit ist es, die Grenzen von Threads und Parallelisierung aufzuzeigen. Dabei soll insbesondere untersucht werden, wie groß der Overhead durch Threads ist und welchen Performanceunterschied es macht, bereits initialisierte Workerthreads zu verwenden, im Vergleich zur Erstellung neuer Threads. Da sich für diese Untersuchungen ein geeigneter, leicht verständlicher und programmierbarer Anwendungsfall anbietet, habe ich mich für Sortieralgorithmen entschieden, die sich zudem sehr gut parallelisieren lassen.

## 1.2 Zielsetzung und Forschungsfrage

Ziel dieser Bachelorarbeit ist die systematische Analyse der Laufzeitentwicklung paralleler Sortierverfahren. Dabei soll untersucht werden, wie sich parallele Implementierungen von Quicksort und Mergesort im Vergleich zu ihren sequentiellen Varianten verhalten. Im Fokus stehen insbesondere folgende Punkte:

- der Einfluss verschiedener Threadingstrategien auf die Laufzeit,
- die Frage, ab welcher Eingangsgröße und bei welcher Anzahl von Threads ein messbarer Geschwindigkeitsvorteil entsteht,
- sowie die Identifikation von Thread-Management-Techniken, die für Sortieralgorithmen die besten Laufzeiten erzielen.

Aus diesen Aspekten ergibt sich die zentrale Forschungsfrage dieser Arbeit: **Unter welchen Bedingungen liefern parallele Sortieralgorithmen anhand von Quicksort und Mergesort einen signifikanten Laufzeitvorteil gegenüber der sequentiellen Ausführung, und welche Threadingstrategien führen dabei zur besten Laufzeit?**

## **2 Theoretische Grundlagen**

- 2.1 Sortieralgorithmen: Quicksort und Mergesort**
- 2.2 Grundlagen der Parallelisierung**
- 2.3 Thread-Modelle, Overheads und Skalierungsgrenzen**

## **3 Methodik und Versuchsaufbau**

- 3.1 Messumgebung und Hardware**
- 3.2 Testaufbau und Implementierungsvarianten**
- 3.3 Messmethodik**

## **4 Ergebnisse und Analyse**

- 4.1 Laufzeitmessungen**
- 4.2 Einfluss der Variablen**
- 4.3 Bewertung der Parallelisierungseffizienz**
- 4.4 Grenzen und Fehlerbetrachtung**

## **5 Diskussion und Fazit**

- 5.1 Interpretation der Ergebnisse**
- 5.2 Beantwortung der Forschungsfrage**
- 5.3 Zusammenfassung**

## **6 Anhang**

- 6.1 Code**
- 6.2 Exakte Hardware-Spezifikationen**