last fixes!!11
[lectures/latex.git] / nlsop / diplom / quellcode.tex
1 \chapter{Funktionen der Programme}
2
3 {\em NLSOP} besteht aus einer Mehrzahl von Programmen.
4 Diese sollen im Folgenden vorgestellt werden.
5 Der vollst"andige Quellcode der {\em NLSOP} Version 2 steht im Internet \footnote{http://www.physik.uni-augsburg.de/\~{}zirkelfr/download/nlsop/nlsop.tar.bz2} zum Download bereit.
6
7   \section{Server}
8   \begin{verbatim}
9 nlsop_server.c
10   \end{verbatim}
11   Es ist ein {\em Server}-Programm, bei dem sich {\em Client} und {\em Benutzeroberfl"ache} anmelden.
12   Dieses verteilt die zu rechnenden Simulationen auf freie {\em Client}-Rechner oder h"alt Simulationsauftr"age in einer Warteschlange.
13   Es nimmt fertige Rechenergebnisse entgegen und speichert sie lokal ab.
14   Es h"alt Statusinformationen "uber die laufenden Rechnungen und die Warteschlange zur Abfrage bereit.
15   Weiterhin nimmt es Simulationsauftr"age entgegen.
16   Die Interaktion mit {\em Client} und {\em Benutzeroberfl"ache} erfolgt durch das Netzwerk "uber eine {\em TCP/IP}-Verbindung.
17
18   \section{Client}
19   \begin{verbatim}
20 nlsop_client.c
21   \end{verbatim}
22   Das {\em Client}-Programm beinhaltet den eigentlichen Simulationscode.
23   Es meldet sich beim {\em Server} an und nimmt Rechenaufgaben entgegen.
24   Nach einer einstellbaren Anzahl von Durchl"aufen "ubergibt es Zwischenergebnisse beziehungsweise das Endergebnis an den {\em Server}-Prozess.
25   Nach Beendigung einer Simulation geht es in den Ruhezustand und wartet auf neue Rechenauftr"age.
26
27   \clearpage
28
29   \section{Benutzeroberfl"ache}
30   \begin{verbatim}
31 nlsop_gui.c
32   \end{verbatim}
33   Die {\em Benutzeroberfl"ache} dient zur "Ubergabe von Simulationsauftr"agen an den {\em Server}.
34   Weiterhin dient es zur Statusabfrage von laufenden Rechnungen, der Warteschlange und der angemeldeten {\em Client}-Rechner.
35
36   \section{Standalone Version}
37   \label{section:sav}
38   \begin{verbatim}
39 nlsop.c
40   \end{verbatim}
41   Die {\em Standalone Version} ist ein eigenst"andiges Programm, das unter anderem auch den Simulationscode beinhaltet.
42   Zus"atzlich stellt sie eine Benutzeroberfl"ache zur Verf"ugung, die die Untersuchung des fertig simulierten Ergebnisses erm"oglicht.
43   Man kann Querschnittsaufnahmen des Targets, die zum Vergleich mit TEM-Aufnahmen benutzt werden k"onnen, sowie Druckspannungen und den Kohlenstoffgehalt visualisieren und als Bitmap abspeichern.
44   Au"serdem kann man Kohlenstoffprofile erzeugen und die Tiefe des Beginns der amorphen Ausscheidungen beziehungsweise der vorderen und hinteren Grenzfl"ache einer vorhandenen durchgehenden Schicht bestimmen.
45
46   \section{APIs}
47
48   Einige Funktionalit"at wurde in externen Programmierschnittstellen ausgelagert.
49   Diese sind im Folgenden vorgestellt.
50   \begin{itemize}
51     \item \begin{verbatim} network.c, network.h \end{verbatim} \\
52           Hilfsmittel zur Verbindung der Programmteile "uber das Netzwerk.
53     \item \begin{verbatim} input.c, input.h \end{verbatim} \\
54           Funktionen f"ur die Benutzereingabe.
55     \item \begin{verbatim} list.c, list.h \end{verbatim} \\
56           Hilfsmittel zur Benutzung von verlinkten Listen.
57     \item \begin{verbatim} display.c, display.h \end{verbatim} \\
58           Funktionen zur Visualisierung auf Konsolenebene.
59     \item \begin{verbatim} event.c, event.h \end{verbatim} \\
60           Hilfsmittel zum Eventmanagement.
61     \item \begin{verbatim} bmp.c, bmp.h \end{verbatim} \\
62           Funktionen f"ur die Erstellung und Bearbeitung von Bitmap Dateien.
63     \item \begin{verbatim} fourier.c, fourier.h \end{verbatim}
64           Funktionen f"ur die diskrete Fouriertransformation.
65     \item \begin{verbatim} dfbapi.c, dfbapi.h \end{verbatim}
66           Helfer f"ur die Visualisierung der Endergebnisse.
67     \item \begin{verbatim} random.c, randomi.h \end{verbatim}
68           Funktionen zur Erzeugung spezieller Wahrscheinlichkeitsverteilungen.
69   \end{itemize}
70
71   \section{Andere Hilfsmittel}
72   \label{section:hilfsmittel}
73   
74   Im Folgenden sind weiter Programme vorgestellt, deren Funktionalit"at aus diversen Gr"unden nicht in die Hauptprogramme eingeflossen ist.
75
76   \begin{itemize}
77     \item \begin{verbatim} nlsop_make_cryst.c \end{verbatim} \\
78           Estellt ein Duplikat eines gespeicherten Ergebnisses wobei alle Zust"ande der Volumen auf \dq Kristallin\dq{} gesetzt werden.
79     \item \begin{verbatim} nlsop_create_cbox.c \end{verbatim} \\
80           Erzeugt ein kristallines Target mit einem plateauf"ormigen Verlauf des Kohlenstoffprofils, das in einer Tiefe von $500 \, nm$ dem Abfall des Kohlenstoffprofils der $180 \, keV$-Implantation entspricht.
81     \item \begin{verbatim} parse_trim_collision.c \end{verbatim} \\
82           Werkzeug zur Auswertung der Datei in der {\em TRIM} detaillierte Daten der Kollisionsereignisse protokolliert.
83     \item \begin{verbatim} dft.c, dft.h \end{verbatim} \\
84           Erstellt die zweidimensionale Fouriertransformation einer Bitmap.
85     \item \begin{verbatim} linescan.c \end{verbatim} \\
86           Erstellt den Linescan "uber eine fouriertransformierte Bitmap.
87     \item \begin{verbatim} random_parse.sh \end{verbatim} \\
88           Simples Shell-Script zur Auswertung und "Uberpr"ufung der Zufallszahlen.
89   \end{itemize}
90
91 \chapter{Publikationsliste}
92
93   \section{Eigene Publikationen}
94
95   \begin{enumerate}
96
97     \item F. Zirkelbach, M. H"aberlen, J. K. N. Lindner, B. Stritzker.\\
98           {\em Modelling of a selforganization process leading to periodic arrays of nanometric amorphous precipitates by ion irradiation.}\\
99           Comp. Mater. Sci. 33 (2005) 310.
100
101     \item F. Zirkelbach, M. H"aberlen, J. K. N. Lindner, B. Stritzker.\\
102           {\em Monte-Carlo-Simulation study of the selforganization of nanometric amorphous precipitates in regular arrays during ion irradiation.}\\
103           Accepted for publication in IBMM 2004 proceedings issue of NIMB.
104
105   \end{enumerate}
106
107   \section{Konferenzbeitr"age}
108
109   \begin{enumerate}
110
111     \item F. Zirkelbach, M. H"aberlen, J. K. N. Lindner und B. Stritzker.\\
112           {\em Monte-Carlo-Simulation der Selbstorganisation amorpher nanometrischer $SiC_x$"=Ausscheidungen in Silizium w"ahrend $C^+$-Ionen-Implantation}\\
113           AKF-Fr"uhjahrstagung der DPG, Regensburg, 2/2004, DS 1.4
114
115     \item F. Zirkelbach, M. H"aberlen, J. K. N. Lindner und B. Stritzker.\\
116           {\em Kinetik des Selbstorganisationsvorganges bei der Bildung von $SiC_x$"=Ausscheidungs-Arrays in $C^+$-Ionen-implantiertem Silizium.}\\
117           69. Jahrestagung der DPG, Berlin, 2/2005, DS 8.6
118
119   \end{enumerate}
120