summaryrefslogtreecommitdiff
path: root/LaTeX/chapters/simulator.tex
blob: d6426c231c82c1436b1ebde32a4a1d5463ff070e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
\chapter{Der Simulator}

\section{Die grafische Benutzerschnittstelle}

\begin{figure}[htbp]
	\centering
	\fbox{\includegraphics{images/ss-neues-fenster-klein}}
	\caption{Der Simulator nach dem ersten Starten}
	\label{fig:NeuesFenster}

\end{figure}
Der Simulator pr\"{a}sentiert sich nach dem ersten Starten wie in Abbildung \ref{fig:NeuesFenster}. F\"{u}r die Erstellung einer neuen Simulation wird im Men\"{u} ``Datei'' (Abbildung \ref{fig:DateiMenue}) der Punkt ``Neue Simulation'' ausgew\"{a}hlt, wo anschließend das Einstellungsfenster f\"{u}r die neu zu erstellende Simulation erscheint.  Auf die einzelnen Optionen wird sp\"{a}ter genauer eingegangen und es werden nun nur die Standardeinstellungen \"{u}bernommen. Die GUI mit einer frischen Simulation sieht dann wie in Abbildung \ref{fig:StandardGUI} aus.

\begin{figure}[htbp]
	\centering
	\fbox{\includegraphics[width=14cm]{images/ss-datei-menu}}
	\caption{``Datei''-Men\"{u}}
	\label{fig:DateiMenue}
\end{figure}

\subsection{Die Men\"{u}zeile}

Im Datei-Men\"{u} (Abbildung \ref{fig:DateiMenue}) lassen sich neue Simulationen erstellen oder die aktuell ge\"{o}ffnete Simulation schliessen. Neue Simulationen \"{o}ffnen sich standardm\"{a}ßig in einem neuen Tab. Es k\"{o}nnen allerdings auch neue Simulationsfenster, die wiederrum eigene Tabs besitzen, ge\"{o}ffnet oder geschlossen werden. In jedem Tab befindet sich eine von den Anderen vollst\"{a}ndig unabh\"{a}ngige Simulation. Es k\"{o}nnen somit beliebig viele Simulationen parallel ausgef\"{u}hrt werden. Die Men\"{u}eintr\"{a}ge ``\"{O}ffnen'', ``Speichern'' und ``Speichern unter'' dienen f\"{u}r das Laden und Speichern von Simulationen. 

\begin{figure}[htbp]
	\centering
	\fbox{\includegraphics{images/ss-neue-simulation-klein}}
	\caption{Standard GUI}
	\label{fig:StandardGUI}
\end{figure}

\"{U}ber das ``Editieren''-Men\"{u} gelangt man zu den Simulationseinstellungen. Es werden auch alle beteiligten Prozesse zum Editieren aufgelistet. Das ``Simulator''-Men\"{u} bietet die selben Optionen wie die Toolbar, welche im n\"{a}chsten Teilkapitel beschrieben wird.

Einige Men\"{u}s sind erst erreichbar, wenn im aktuellen Fenster bereits eine Simulation erstellt oder geladen wurde.

\subsection{Die Toolbar}

Oben links befindet sich die Toolbar (Abbildung \ref{fig:Toolbar}) des Simulators. Die Toolbar enth\"{a}lt die Funktionen, die vom Benutzer am h\"{a}ufigsten verwendet werden.

\begin{figure}[htbp]
	\centering
	\fbox{\includegraphics[width=5cm]{images/ss-neue-simulation-toolbar}}
	\caption{Die Men\"{u}zeile inklusive Toolbar}
	\label{fig:Toolbar}
\end{figure}

Die Toolbar bietet vier verschiedene Aktionen an:

\begin{itemize}
	%\setlength{\itemsep}{-1mm}
	\item Starten der Simulation; kann nur bet\"{a}tigt werden, wenn die Simulation derzeit nicht l\"{a}uft.
	\item Pausieren der Simulation, kann nur bet\"{a}tigt werden, wenn die Simulation derzeit l\"{a}uft.
	\item Wiederholen der Simulation, kann nicht bet\"{a}tigt werden, wenn die Simulation noch nicht gestartet wurde. 
	\item Zur\"{u}cksetzen der Simulation, kann nur bet\"{a}tigt werden, wenn die Simulation pausiert wurde oder wenn die Simulation abgelaufen ist.
\end{itemize}

Die Toolbar l\"{a}sst sich auch nach Belieben repositionieren (z.B. links, rechts oder unten des Simulatorfensters). Hierf\"{u}r muss per ``Drag-n-Drop'' die ``raue Fl\"{a}che'' zur Zielposition gezogen werden.

\subsection{Die Visualisierung}

\begin{figure}[htbp]
	\centering
	\fbox{\includegraphics[width=14cm]{images/ss-visualisierung}}
	\caption{Visualisierung einer noch nicht gestarteten Simulation}
	\label{fig:Visualisierung}
\end{figure}

Mittig rechts (Abbildung \ref{fig:StandardGUI}) befindet sich die grafische Repr\"{a}sentation der Simulation. Die X-Achse repr\"{a}sentiert die Zeit in Millisekunden. Die aktuelle Simulation endet nach genau 15 Sekunden. In Abbildung \ref{fig:Visualisierung} sind 3 Prozesse (mit den PIDs 1, 2 und 3) dargestellt, die jeweils einen eigenen horizontalen schwarzen Balken besitzen. Auf diesen Prozessbalken kann man die jeweilige lokale Prozesszeit ablesen. Die vertikale rote Linie stellt die globale Zeit dar. 

Die Prozessbalken dienen auch f\"{u}r Start- und Zielpunkte von Nachrichten. Wenn beispielsweise Prozess 1 eine Nachricht zum Prozess 2 verschickt, so wird eine Linie vom einen Prozessbalken zum Anderen gezeichnet. Nachrichten, die ein Prozess an sich selbst schickt, werden nicht visualisiert.

Mit einem Linksklick auf einen Prozessbalken ist es ebenso m\"{o}glich einen Prozess zu editieren. Dies muss also nicht zwingend \"{u}ber das ``Simulator''-Men\"{u} geschehen. Ein Rechtsklick hingegen \"{o}ffnet ein Popup-Fenster mit weiteren Auswahlm\"{o}glichkeiten (Abbildung \ref{fig:RechtsklickProzessbalken}). Ein Prozess kann \"{u}ber das Popup-Men\"{u} nur dann abst\"{u}rzen oder wiederbelebt werden, wenn die Simulation aktuell l\"{a}uft.

\begin{figure}[htbp]
	\centering
	\fbox{\includegraphics[width=8.8cm]{images/ss-rechtsklick-prozessbalken}}
	\caption{Rechtsklick auf einen Prozessbalken}
	\label{fig:RechtsklickProzessbalken}
\end{figure}

Generell kann die Anzahl der Prozesse nach belieben variieren. Die Dauer der Simulation betr\"{a}gt mindestens 5 -und maximal 120 Sekunden. Die Simulation endet erst, wenn die globale Zeit 15 Sekunden erreicht hat, und nicht, wenn eine lokale Prozesszeit die 15 Sekunden erreicht.

\subsubsection{Farbliche Differenzierung}

F\"{u}r Visualisierung einer Simulation spielen Farben eine große Rolle. Standardm\"{a}ßig werden die Prozesse (Prozessbalken) und Nachrichten mit den Farben wie in Tabelle \ref{tb:Farben} aufgelistet dargestellt. Dies sind lediglich die Standarfarben, welche man \"{u}ber die Einstellungen neudefinieren kann.

\begin{table}
	\fbox{
	\begin{tabular}{c|l}
		\textbf{Prozessfarbe} & \textbf{Bedeutung} \\
		\hline 
		 	Schwarz & Simulation l\"{a}uft derzeit nicht (z.B. noch nicht gestartet, abgelaufen oder\\
				& pausiert)\\
		 	Orange & Die Maus befindet sich \"{u}ber den Prozessbalken\\
		 	Rot & Der Prozess ist abgest\"{u}rzt\\
			& \\
		\textbf{Nachrichtfarbe} & \textbf{Bedeutung} \\
		\hline 
		 	Gr\"{u}n & Die Nachricht ist noch unterwegs hat das Ziel noch nicht erreicht\\
		 	Blau & Die Nachricht hat das Ziel erfolgreich erreicht\\
		 	Rot & Die Nachricht ging verloren (entweder weil der Zielprozess abgest\"{u}rzt ist\\
				& oder weil sie unterwegs verloren ging)\\

	\end{tabular}\\
	}
	\caption{Farbliche Differenzierung von Prozessen und Nachrichten}
	\label{tb:Farben}
\end{table}

\subsection{Die Sidebar}

Mithilfe der Sidebar (mittig links, Abbildung \ref{fig:StandardGUI}) lassen sich Ereignisse bestimmter Prozesse verwalten. Ganz oben (Abbildung \ref{fig:Sidebar}) ist der zu verwaltende Prozess selektiert (hier mit der PID 1). In dieser Prozessauswahl gibt es auch die M\"{o}glichkeit ``Alle Prozesse'' auszuw\"{a}hlen, womit die Ereignisse aller Prozesse gleichzeitig verwaltet werden k\"{o}nnen. Unter ``Lokale Ereignisse'' versteht man die Ereignisse, die auftreten, wenn die zum jeweiligen Prozess lokale Prozesszeit eingetreten ist. Die darunterliegende Ereignistabelle listet alle programmierten Ereignisse (hier noch keine vorhanden) mitsamt Eintrittszeit sowie PID auf.

\begin{figure}[htbp]
	\centering
	\fbox{\includegraphics[width=9cm]{images/ss-sidebar}}
	\caption{Die Sidebar}
	\label{fig:Sidebar}
\end{figure}

F\"{u}r die Erstellung eines neuen Ereignisses kann man entweder mit Rechtsklick auf einen Prozessbalken (Abbildung \ref{fig:RechtsklickProzessbalken}) klicken, oder unterhalb der Ereignistabelle ein Ereignis ausw\"{a}hlen (Abbildung \ref{fig:Ereignisauswahl}), im Textfeld die Zeit eintragen und auf ``\"{U}bernehmen'' klicken. Beispielsweise wurden auf Abbildung \ref{fig:SidebarMitEreignissen} drei Ereignisse hinzugef\"{u}gt: Absturz nach 123ms, Wiederbelebung nach 321ms und erneuerter Absturz nach 3000ms des Prozesses mit der ID 1. 

\begin{figure}[htbp]
	\centering
	\fbox{\includegraphics[width=9cm]{images/ss-ereignisauswahl}}
	\caption{Die Ereignisauswahl via Sidebar}
	\label{fig:Ereignisauswahl}
\end{figure}

Mit Rechtsklick lassen sich alle selektierten Ereignisse entweder kopieren oder l\"{o}schen. Die Spalten f\"{u}r die Zeit und der PID lassen sich nachtr\"{a}glich editieren. Somit besteht eine komfortable M\"{o}glichkeit bereits programmierte Ereignisse auf eine andere Zeit zu verschieben oder einem anderen Prozess zuzuweisen.

Neben dem ``Ereignis''-Tab gibt es in der Sidebar einen Tab mit dem Namen ``Variablen''. Dort kann man alle Variablen des aktuell ausgew\"{a}hlten Prozesses editieren. Mehr dazu aber sp\"{a}ter. 

\begin{figure}[htbp]
	\centering
	\fbox{\includegraphics[width=9cm]{images/ss-sidebar-mit-ereignissen}}
	\caption{Der Ereigniseditor mit 3 programmierten Ereignissen}
	\label{fig:SidebarMitEreignissen}
\end{figure}

\subsection{Das Loggfenster}

Das Loggfenster (Abbildung \ref{fig:StandardGUI}, unten) protokolliert  in chronologischer Reihenfolge alle eingetroffenen Ereignisse. Auf Abbildung \ref{fig:Loggfenster} sieht man das Loggfenster nach Erstellung unserer Simulation, an welcher 3 Prozesse beteiligt sind. Am Anfang eines Loggeintrages wird stets die globale Zeit in Millisekunden protokolliert. Bei jedem Prozess wird ebenso seine lokale Zeit sowie die Lamport- und die Vektor-Zeitstempel aufgef\"{u}hrt. Letztere werden sp\"{a}ter genauer behandelt. 

\begin{figure}[htbp]
	\centering
	\fbox{\includegraphics[width=16.5cm]{images/ss-loggfenster}}
	\caption{Das Loggfenster}
	\label{fig:Loggfenster}
\end{figure}

Mit dem Deaktivieren der Checkbox ``Logging'' l\"{a}ßt sich das direkte Loggen von Nachrichten tempor\"{a}r ausstellen. Ohne aktivierter Checkbox erscheinen keine neuen Nachrichten mehr im Loggfenster. Nach Reaktivieren der Checkbox werden alle ausgelassenen Nachrichten nachtr\"{a}glich in das Fenster geschrieben. Eine Deaktivierung des Loggings kann zu verbessertem Leistungsverhalten des Simulators f\"{u}hren (z.B. kein Rucklen; ist vom verwendeten Computer, auf dem der Simulator l\"{a}uft, abh\"{a}ngig). 

\"{U}ber die Checkbox ``Expertenmodus'' wird der Expertenmodus aktiviert beziehungsweise deaktiviert. 

\subsection{Der Expertenmodus}
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 
 lsdkfjds lfjds flsjfsljsd flsdjf sldkfjsdlfkj 


\subsubsection{Lamport- und Vektorzeit}

\subsubsection{Loggfilter}

\subsubsection{Lokale und globale Ereignisse}

\section{Ereignisse}

\subsection{Prozessabsturz}

\subsection{Prozesswiederbelebung}

\subsection{Aktivierung und Deaktivierung von Protokollen}

\subsection{Weitere Protokollereignisse}

\section{Protokolle}

\subsection{Beispiel (Dummy) Protokoll}

\subsection{Das Ping-Pong Protokoll}

\subsection{Das Broadcast-Sturm Protokoll}

\subsection{Das Protokoll zur internen Synchronisierung in einem synchronen System}

\subsection{Christians Methode zur externen Synchronisierung}

\subsection{Berkeley Algorithmus zur internen Synchronisation}

\subsection{Das Ein-Phasen Commit Protokoll}

\subsection{Das Zwei-Phasen Commit Protokoll}

\subsection{Der ungen\"{u}gende (Basic) Multicast}

\subsection{Der zuverl\"{a}ssige (Reliable) Multicast}

\section{Zeitformate}

\subsection{``Normale Zeit''}

\subsection{Die Logische Uhr von Lamport}

\subsection{Die Vektor-Zeitstempel}

\section{Einstellungen}

\subsection{Simulationseinstellungen}

\subsection{Prozesseinstellungen}

\subsection{Protokolleinstellungen}

TODO: Farben der Prozessbalken, Farben der Nachrichten